ASP.NET中數據庫的設置初步----DataSet設置數據庫
發表時間:2024-02-17 來源:明輝站整理相關軟件相關文章人氣:
[摘要]前面我們已經說了如何操作數據庫,但幾乎全部是通過OleDbCommand和OleDbDataReader來做的,這次我們說說如何通過OleDbDataAdapter來操作數據庫!關于OleDbDataAdapter的用法實際上我們在以前已經講過了,由于OleDbDataAdapter是DataSe...
前面我們已經說了如何操作數據庫,但幾乎全部是通過OleDbCommand和OleDbDataReader來做的,這次我們說說如何通過OleDbDataAdapter來操作數據庫!關于OleDbDataAdapter的用法實際上我們在以前已經講過了,由于OleDbDataAdapter是DataSet和數據源之間建立聯系的一個橋梁,而DataSet用于對單層數據、XML 數據和關系數據進行存儲、遠程處理和編程!。
我們曾經講過利用Command來對數據庫進行增加、刪除和修改操作,但是我們利用DataSet和DataAdapter能夠更加方便的對數據庫進行操作,基本是我們可以認為DataSet是專門為WEB而設計的,這也是ADO.NET和ADO的一個重要的區別。
下面是DataSet和SQL數據的的關系圖, 通過這個圖我們可以看出DataSet和DataAdapter以及SQL數據庫的關系。
下面我們來講解一下如何利用DataSet和DataAdapter來操作上據庫
MyConnection.Open(); //打開數據庫,請參考前面文章的內容
MyCommand.Connection = MyConnection; //設置Command,請參考前面文章的內容
MyCommand. CommandText = “select * from admin”; //設置Command,參考前面文章的內容
OleDbDataAdapter MyDataAdapter = new OleDbDataAdapter(); //定義OleDbDataAdapte對象
MyDataAdapter.SelectCommand = MyCommand; //設置OleDbDataAdapte對象的SelectCommand屬性
System.Data.DataSet MyDataSet = new System.Data.DataSet(); //定義DataSet
MyDataAdapter.Fill(MyDataSet,"admin"); //通過OleDbDataAdapte對象的SelectCommand屬性填充MyDataSet
MyConnection.Close(); //關閉數據庫
整個過程分以下幾步:
1.建立數據庫連接(打開數據庫,請參考前面文章的內容)
2.建立OleDbDataAdapter對象!
3.實例化OleDbDataAdapter對象!
4.建立一個DataSet對象,執行SQL語句得到的表添加到其中
5.關閉數據庫連接
通過上面的步驟我們就可以使用DataBind將DataSet中的數據綁定到特定的控件上了。ㄏ乱徽挛覀儗⒅v解如何邦定數據庫)
我們說過但是我們可以利用DataSet和DataAdapter能夠更加方便的對數據庫進行操作,如何通過OleDbDataAdapter來執行數據庫的操作的,我們只需要對DataSet中的數據進行增加、刪除、修改等操作,然后在將DataSet提交給數據庫即可
//利用利用DataSet和DataAdapter操作數據庫
public Boolean DoDB()
{
MyConnection.Open(); //打開數據庫,請參考前面文章的內容
MyCommand.Connection = MyConnection; //設置Command,請參考前面文章的內容
MyCommand. CommandText = “select * from admin”; //設置Command,參考前面文章的內容
OleDbDataAdapter MyDataAdapter = new OleDbDataAdapter(); //定義OleDbDataAdapte對象
MyDataAdapter.SelectCommand = MyCommand; //設置OleDbDataAdapte對象的SelectCommand屬性
System.Data.DataSet MyDataSet = new System.Data.DataSet(); //定義DataSet
MyDataAdapter.Fill(MyDataSet,"admin"); //通過OleDbDataAdapte對象的SelectCommand屬性填充MyDataSet
OleDbCommandBuilder MyCommandBuild = new OleDbCommandBuilder(MyDataAdapter);//關聯DataSet和數據庫的操作的,必不可少
foreach(DataRow dr in MyDataSet.Tables["Admin"].Rows)
{
if(dr["Admin_Code"].ToString().Trim().Equals("a"))
{
dr.Delete(); //刪除DataSet 中的行
}
}
MyDataSet.Tables["Admin"].Rows[0][0] = "ss";//更新DataSet中第一行第一列的值
string [] dd = new String[3]{"a","b","v"};
MyDataSet.Tables["Admin"].Rows.Add(dd);//增加一行
MyDataAdapter.Update(MyDataSet,"Admin");//將DataSet中”Admin”表中的數據提交給數據庫,完成數據庫的更新
MyConnection.Close();//關閉數據庫
}
這個程序和我們前面用到的利用Command的delete、insert、update例程是執行同樣的功能的,我這里改成了用MyDataAdapter來達到同樣的效果!
要通過MyDataAdapter執行對數據庫的操作,我們要有下面的幾步:
1. 建立數據庫連接MyConnection
2. 實例化OleDbDataAdapter對象!
3. 建立一個DataSet對象,并把執行select語句得到的記錄添加到其中
4. 建立OleDbCommandBuilder對象! 并讓它與我們前面的OleDbDataAdapter對象關聯!語句如下:OleDbCommandBuilder MyCommandBuild = new OleDbCommandBuilder(MyDataAdapter);
5. 對DataSet中包含表的特定記錄進行增加、刪除、修改
6. 執行OleDbDataAdapter對象的Update命令更新數據庫,語句如下: MyDataAdapter.Update(ds,"notes");
7. 關閉數據庫連接
總結:
DataSet是ADO.NET中非常重要的內容,也是ADO.NET和ADO的區別的一個重要表現,特別適合成批的數據操作,也是數據棒定的重要來源。OleDbDataAdapter是DataSet和數據源之間建立聯系的一個橋梁,要熟練的使用DataSet我們需要熟練的掌握OleDbDataAdapter。下一章我們將講述Data