ADO.NET中的五個主要對象的詳細介紹與應用
2024-07-10 12:41:08
供稿:網友
首先看一個例子
配置文件
代碼如下:
<configuration>
<connectionStrings>
<add name=connStr" connectionString="Data Source=./SQLEXPRESS;AttachDBFilename=|DataDirectory|/SS.mdf;Integrated Security=true;User Instance=True"/>
</connectionStrings>
</configuration>
代碼
代碼如下:
string strconn = ConfigurationManager.ConnectionStrings["connStr"].ConnectionString; //從配置文件中讀取連接字符串
using (SqlConnection conn = new SqlConnection(strconn)) //創建連接對象,出了using范圍,連接自動關閉,對象自動銷毀
{
conn.Open();//打開連接
using (SqlCommand cmd = conn.CreateCommand()) //創建命令對象
{
cmd.CommandText = "select * from T_Persons";//命令內容
DataSet dataset = new DataSet(); //創建一個數據集,相當于一個數據容器
SqlDataAdapter adapter = new SqlDataAdapter(cmd); //創建一個適配器
adapter.Fill(dataset); //將查詢結果填充到數據集中
DataTable datatable = dataset.Tables[0]; //將查詢到的一張表保存在DataTable對象中
for (int i = 0; i < datatable.Rows.Count;i++ )//遍歷
{
DataRow row = datatable.Rows[i];//取得一行對象
string name=row["F_Name"].ToString();//取得該行對應列的值
MessageBox.Show(name);
}
}
}
對象解析
代碼如下:
Connection:
和數據庫交互,必須連接它。連接幫助指明數據庫服務器、數據庫名字、用戶名、密碼,和連接數據庫所需要的其它參數。Connection對象會被Command對象使用,這樣就能夠知道是在哪個數據源上面執行命令。
Command:
主要可以用來對數據庫發出一些指令,例如可以對數據庫下達查詢、新增、修改、刪除數據等指令,以及呼叫存在數據庫中的預存程序等。這個對象是架構在Connection 對象上,也就是Command 對象是透過連結到數據源。
DataAdapter:
主要是在數據源以及DataSet 之間執行數據傳輸的工作,它可以透過Command 對象下達命令后,并將取得的數據放入DataSet 對象中。這個對象是架構在Command對象上,并提供了許多配合DataSet 使用的功能。
DataSet:
這個對象可以視為一個暫存區(Cache),可以把從數據庫中所查詢到的數據保留起來,甚至可以將整個數據庫顯示出來。DataSet 的能力不只是可以儲存多個Table 而已,還可以透過DataAdapter對象取得一些例如主鍵等的數據表結構,并可以記錄數據表間的關聯。DataSet 對象可以說是ADO.NET 中重量級的對象,這個對象架構在DataAdapter對象上,本身不具備和數據源溝通的能力;也就是說我們是將DataAdapter對象當做DataSet 對象以及數據源間傳輸數據的橋梁。
DataReader:
當我們只需要循序的讀取數據而不需要其它操作時,可以使用DataReader 對象。DataReader對象只是一次一筆向下循序的讀取數據源中的數據,而且這些數據是只讀的,并不允許作其它的操作。因為DataReader 在讀取數據的時候限制了每次只讀取一筆,而且只能只讀,所以使用起來不但節省資源而且效率很好。使用DataReader 對象除了效率較好之外,因為不用把數據全部傳回,故可以降低網絡的負載。ADO.NET 使用Connection 對象來連接數據庫,使用Command 或DataAdapter對象來執行SQL語句,并將執行的結果返回給DataReader 或 DataAdapter ,然后再使用取得的DataReader 或DataAdapter 對象操作數據結果。