轉發自:http://www.cnblogs.com/rainman/archive/2012/03/13/2393975.html
- 1、概述
- 2、連線字串的寫法
- 3、SqlConnection物件
- 4、SqlCommand物件
- 5、SqlDataReader物件
- 6、DataSet物件
- 7、釋放資源
1、概述
ado.net提供了豐富的資料庫操作,這些操作可以分為三個步驟:
- 第一,使用SqlConnection物件連線資料庫;
- 第二,建立SqlCommand物件,負責SQL語句的執行和儲存過程的呼叫;
- 第三,對SQL或儲存過程執行後返回的“結果”進行操作。
對返回“結果”的操作可以分為兩類:
- 一是用SqlDataReader直接一行一行的讀取資料集;
- 二是DataSet聯合SqlDataAdapter來運算元據庫。
兩者比較:
- SqlDataReader時刻與遠端資料庫伺服器保持連線,將遠端的資料通過“流”的形式單向傳輸給客戶端,它是“只讀”的。由於是直接訪問資料庫,所以效率較高,但使用起來不方便。
- DataSet一次性從資料來源獲取資料到本地,並在本地建立一個微型資料庫(包含表、行、列、規則、表之間的關係等),期間可以斷開與伺服器的連線,使用SqlDataAdapter物件操作“本地微型資料庫”,結束後通過SqlDataAdapter一次性更新到遠端資料庫伺服器。這種方式使用起來更方,便簡單。但效能較第一種稍微差一點。(在一般的情況下兩者的效能可以忽略不計。)
一張十分出名的ADO.NET結構圖:
2、連線字串的寫法
string connectString = "Data Source=.;Initial Catalog=Student;Integrated Security=True";
3、SqlConnection物件
名稱空間:System.Data.SqlClient.SqlConnection;
返回資料庫連線物件,引數字串。例項化“連線物件”,並開啟連線
SqlConnection sqlCnt = new SqlConnection(connectString); sqlCnt.Open();
使用完成後,需要關閉“連線物件”
sqlCnt.Close();
4、SqlCommand物件
名稱空間:System.Data.SqlClient.SqlCommand;
SqlCommand物件用於執行資料庫操作,操作方式有三種:
- SQL語句:command.CommandType = CommandType.Text;
- 儲存過程:command.CommandType = CommandType.StoredProcedure;
- 整張表:command.CommandType = CommandType.TableDirect;
例項化一個SqlCommand物件
SqlCommand command = new SqlCommand(); command.Connection = sqlCnt; // 繫結SqlConnection物件
或直接從SqlConnection建立
SqlCommand command = sqlCnt.CreateCommand();
常用方法:
- command.ExecuteNonQuery(): 返回受影響函式,如增、刪、改操作;
- command.ExecuteScalar():執行查詢,返回首行首列的結果;
- command.ExecuteReader():返回一個資料流(SqlDataReader物件)。
常用操作
① 執行SQL
SqlCommand cmd = conn.CreateCommand(); //建立SqlCommand物件 cmd.CommandType = CommandType.Text; cmd.CommandText = "select * from products = @ID"; //sql語句 cmd.Parameters.Add("@ID", SqlDbType.Int); cmd.Parameters["@ID"].Value = 1; //給引數sql語句的引數賦值
② 呼叫儲存過程
SqlCommand cmd = conn.CreateCommand(); cmd.CommandType = System.Data.CommandType.StoredProcedure; cmd.CommandText = "儲存過程名";
③ 整張表
SqlCommand cmd = conn.CreateCommand(); cmd.CommandType = System.Data.CommandType.TableDirect; cmd.CommandText = "表名"
5、SqlDataReader物件
名稱空間:System.Data.SqlClient.SqlDataReader;
SqlDataReader物件提供只讀單向資料的功能,單向:只能依次讀取下一條資料;只讀:DataReader中的資料是隻讀的,不能修改;相對地DataSet中的資料可以任意讀取和修改.
它有一個很重要的方法,是Read(),返回值是個布林值,作用是前進到下一條資料,一條條的返回資料,當布林值為真時執行,為假時跳出。如
SqlCommand command = new SqlCommand(); command.Connection = sqlCnt; command.CommandType = CommandType.Text; command.CommandText = "Select * from Users"; SqlDataReader reader = command.ExecuteReader(); //執行SQL,返回一個“流” while (reader.Read()) { Console.Write(reader["username"]); // 列印出每個使用者的使用者名稱 }
6、DataSet物件
6.1 SqlDataAdapter;
名稱空間:System.Data.SqlClient.SqlDataAdapter;
SqlDataAdapter是SqlCommand和DataSet之間的橋樑,例項化SqlDataAdapter物件:
SqlConnection sqlCnt = new SqlConnection(connectString); sqlCnt.Open(); // 建立SqlCommand SqlCommand mySqlCommand = new SqlCommand(); mySqlCommand.CommandType = CommandType.Text; mySqlCommand.CommandText = "select * from product"; mySqlCommand.Connection = sqlCnt; // 建立SqlDataAdapter SqlDataAdapter myDataAdapter = new SqlDataAdapter(); myDataAdapter.SelectCommand = mySqlCommand; // 為SqlDataAdapter物件繫結所要執行的SqlCommand物件
上述SQL可以簡化為
SqlConnection sqlCnt = new SqlConnection(connectString); sqlCnt.Open(); // 隱藏了SqlCommand物件的定義,同時隱藏了SqlCommand物件與SqlDataAdapter物件的繫結 SqlDataAdapter myDataAdapter = new SqlDataAdapter("select * from product", sqlCnt);
屬性和方法
- myDataAdapter.SelectCommand屬性:SqlCommand變數,封裝Select語句;
- myDataAdapter.InsertCommand屬性:SqlCommand變數,封裝Insert語句;
- myDataAdapter.UpdateCommand屬性:SqlCommand變數,封裝Update語句;
- myDataAdapter.DeleteCommand屬性:SqlCommand變數,封裝Delete語句。
- myDataAdapter.fill():將執行結果填充到Dataset中,會隱藏開啟SqlConnection並執行SQL等操作。
6.2 SqlCommandBuilder;
名稱空間:System.Data.SqlClient.SqlCommandBuilder。
對DataSet的操作(更改、增加、刪除)僅是在本地修改,若要提交到“資料庫”中則需要SqlCommandBuilder物件。用於在客戶端編輯完資料後,整體一次更新資料。具體用法如下:
SqlCommandBuilder mySqlCommandBuilder = new SqlCommandBuilder(myDataAdapter); // 為myDataAdapter賦予SqlCommandBuilder功能 myDataAdapter.Update(myDataSet, "表名"); // 向資料庫提交更改後的DataSet,第二個引數為DataSet中的儲存表名,並非資料庫中真實的表名(二者在多數情況下一致)。
6.3 DataSet
名稱空間:System.Data.DataSet。
資料集,本地微型資料庫,可以儲存多張表。
使用DataSet第一步就是將SqlDataAdapter返回的資料集(表)填充到Dataset物件中:
SqlDataAdapter myDataAdapter = new SqlDataAdapter("select * from product", sqlCnt); DataSet myDataSet = new DataSet(); // 建立DataSet myDataAdapter.Fill(myDataSet, "product"); // 將返回的資料集作為“表”填入DataSet中,表名可以與資料庫真實的表名不同,並不影響後續的增、刪、改等操作
① 訪問DataSet中的資料
SqlDataAdapter myDataAdapter = new SqlDataAdapter("select * from product", sqlCnt); DataSet myDataSet = new DataSet(); myDataAdapter.Fill(myDataSet, "product"); DataTable myTable = myDataSet.Tables["product"]; foreach (DataRow myRow in myTable.Rows) { foreach (DataColumn myColumn in myTable.Columns) { Console.WriteLine(myRow[myColumn]); //遍歷表中的每個單元格 } }
② 修改DataSet中的資料
SqlDataAdapter myDataAdapter = new SqlDataAdapter("select * from product", sqlCnt); DataSet myDataSet = new DataSet(); myDataAdapter.Fill(myDataSet, "product"); // 修改DataSet DataTable myTable = myDataSet.Tables["product"]; foreach (DataRow myRow in myTable.Rows) { myRow["name"] = myRow["name"] + "商品"; } // 將DataSet的修改提交至“資料庫” SqlCommandBuilder mySqlCommandBuilder = new SqlCommandBuilder(myDataAdapter); myDataAdapter.Update(myDataSet, "product");
注意:在修改、刪除等操作中表product必須定義主鍵,select的欄位中也必須包含主鍵,否則會提示“對於不返回任何鍵列資訊的 SelectCommand,不支援 UpdateCommand 的動態 SQL 生成。”錯誤
③ 增加一行
SqlDataAdapter myDataAdapter = new SqlDataAdapter("select * from product", sqlCnt); DataSet myDataSet = new DataSet(); myDataAdapter.Fill(myDataSet, "product"); DataTable myTable = myDataSet.Tables["product"]; // 新增一行 DataRow myRow = myTable.NewRow(); myRow["name"] = "捷安特"; myRow["price"] = 13.2; //myRow["id"] = 100; id若為“自動增長”,此處可以不設定,即便設定也無效 myTable.Rows.Add(myRow); // 將DataSet的修改提交至“資料庫” SqlCommandBuilder mySqlCommandBuilder = new SqlCommandBuilder(myDataAdapter); myDataAdapter.Update(myDataSet, "product");
④ 刪除一行
SqlDataAdapter myDataAdapter = new SqlDataAdapter("select * from product", sqlCnt); DataSet myDataSet = new DataSet(); myDataAdapter.Fill(myDataSet, "product"); // 刪除第一行 DataTable myTable = myDataSet.Tables["product"]; myTable.Rows[0].Delete(); SqlCommandBuilder mySqlCommandBuilder = new SqlCommandBuilder(myDataAdapter); myDataAdapter.Update(myDataSet, "product");
屬性
- Tables:獲取包含在DataSet中的表的集合。
- Relations:獲取用於將錶連結起來並允許從父表瀏覽到子表的關係的集合。
- HasEroors:表明是否已經初始化DataSet物件的值。
方法
- Clear清除DataSet物件中所有表的所有資料。
- Clone複製DataSet物件的結構到另外一個DataSet物件中,複製內容包括所有的結構、關係和約束,但不包含任何資料。
- Copy複製DataSet物件的資料和結構到另外一個DataSet物件中。兩個DataSet物件完全一樣。
- CreateDataReader為每個DataTable物件返回帶有一個結果集的DataTableReader,順序與Tables集合中表的顯示順序相同。
- Dispose釋放DataSet物件佔用的資源。
- Reset將DataSet物件初始化。
7、釋放資源
資源使用完畢後應及時關閉連線和釋放,具體方法如下:
myDataSet.Dispose(); // 釋放DataSet物件 myDataAdapter.Dispose(); // 釋放SqlDataAdapter物件 myDataReader.Dispose(); // 釋放SqlDataReader物件 sqlCnt.Close(); // 關閉資料庫連線 sqlCnt.Dispose(); // 釋放資料庫連線物件