雖然我們都知道ADO.NET是對數據庫的操作,但是要真的說出ADO.NET的具體含義還不是很容易。
ADO.NET是ActiveX Data Objects的縮寫,它是一個COM組件庫,用于在microsoft技術中訪問數據。之所以叫ADO.NET,應該是微軟自己打的廣告,希望在NET編程環境中優先使用這種數據訪問接口。上面這段話基本來自百度百科。簡單來說,ADO.NET就是一種數據訪問接口,可以讓我們在程序中調用相應的類庫對數據庫(通常為SQL Server,也可以是access 等其他數據庫)進行增刪改查等操作。
ADO.NET的幾大組成部分
ADO.NET由五大類庫組成,分別是:
Connection(用于建立與 數據庫的連接)
Command(用于執行SQL語句)
DataReader(用于讀取數據)
DataAdapter(用于填充把數據填充到DataSet)
DataSet(數據集,用于程序中)
通常,從程序中訪問數據庫的方法是:
創建一個到數據庫的連接
打開數據庫連接
創建ADO記錄集
從記錄集中提取需要的數據
關閉記錄集
關閉連接
下面就分別根據這一個過程結合ADO.NET的五大類庫進行解釋。
要想使用ADO.NET需要在程序中引用System.Data.SqlClient。其中包含了對Sql Server進行操作的數據訪問類:
SqlConnection:連接數據庫
SqlCommand:數據庫命名對象
SqlCommandBuilder:生成SQL命令
SqlDataReader:數據讀取器
SqlDataAdapter:數據適配器,用于填充DataSet
SqlParameter:為存儲過程定義參數
SqlTransaction:數據庫事務
建立連接
首先,要想訪問數據庫,我們需要一個媒介把程序與數據庫連接起來。這就是連接字符串,它的基本語法為:Data Source(數據源) + Initial Catalog(數據庫名稱) + User ID(用戶名) + Password(密碼)。
或者
注意:對于Sql Server來說,它支持兩種身份驗證方法,一種是windows身份驗證,另一種是Sql Server身份驗證。如果要用windows身份驗證,就需要在連接字符串中包括Integrated Security屬性。該屬性默認為False。需要設置為True后才能使用windows身份驗證。
除了這幾個必須的字段,連接字符串中還有許多可選的屬性,在這里我就不一一列舉,列出一些相關資料供感興趣的朋友自行查閱,一個連接字符串可以包含哪些屬性。
接著,有了連接字符串就可以創建連接對象了。
SqlConnection connection = new SqlConnection(connecString);
或者可以使用專門的連接字符串生成器:
然后使用連接對象可以打開或關閉連接。
connection.Open();
connection.Close();
執行命令
打開連接之后就可以操作數據庫了,在這里需要用到SqlCommand命令對象。
它具有四個主要屬性,這些屬性會在初始化的時候賦默認值:
CommandText:空字符串(”“)
CommandTimeout:30
CommandType:CommandType.Text
Connection:Null
創建命令對象:
- SqlCommand command = connection.CreateCommand();
新聞熱點
疑難解答
圖片精選