Command對象主要用來運行SELECT、INSERT、UPDATE或DELETE之類的SQL語句。Command對象還可以調用存儲過程或從特定表中取得記錄。
DataReader對象主要是用來讀取數據結果,使用它讀取記錄時通常比從DataSet更快。DataReader類有三種:SqlDataReader、OleDbDataReader和OdbcDataReader。DataReader對象用Commmand對象從數據庫中讀取記錄,並且DataReader對象只能向前的讀取記錄,用於在某些情況下替代DataSet對象(DataSet對象可以存儲數據庫中的行拷貝,可以在切斷數據庫的連接時處理這個拷貝,我們將在以後的章節中詳細介紹該對象)。
注意:不能用DataReader修改數據庫中的記錄,它是採用向前的,只讀的方式讀取數據庫。
SqlCommand類
SqlCommand對象用於對Sql Server數據庫執行命令。OleDbCommand對象用於對支持OleDb的數據庫執行命令,如Oracle與Access。OdbcCommand對象用於對支持Odbc的數據庫執行命令。儘管SqlCommand類是針對Sql Server的,但是這個類的許多屬性、方法與事件和OleDbCommand及OdbcCommand等類相似。本章將重點講解SqlCommand特定的屬性與方法,其他的Command類你可以參考相應的幫助文檔。
注意:使用不同的Command對象需要導入不同的命名空間。OleDbCommand的命名空間爲System.Data.OleDb。SqlCommand的命名空間爲System.Data.SqlClient。OdbcCommand的命名空間爲System.Data.Odbc。
SqlCommand屬性:
屬性 | 說明 |
CommandText | 其返回類型爲string, 獲取或設置要對數據源執行的 SQL 語句、存儲過程或表。 |
CommandTimeOut | 其返回類型爲int,獲取或設置在終止執行命令的嘗試並生成錯誤之前的等待時間。 |
CommandType | 其返回類型爲CommandType,讀取或設置表示CommandText屬性將如何被解釋的值,其有效的值可以爲CommandType.Text、CommandType.StoredProcedur與CommandType.TableDirect,分別表示SQL語句、存儲過程調用或要讀取的表,默認爲Text。 |
Connection | 其返回類型爲string, 獲取或設置 SqlCommand 的此實例使用的 SqlConnection。 |
Parameters | 其返回類型爲SqlParameterCollection,取得提供給命令的參數(如有)。 |
SqlCommand方法:
方法 | 說明 |
Cancle() | 其返回類型爲void,取消命令的執行 |
CreateParameter() | 其返回類型爲SqlParameter, 用於創建 SqlParameter 對象的新實例。 |
ExecuteNonQuery() | 其返回類型爲int,執行不返回結果集的Sql語句,包括INSERT、UPDATE與DELETE語句、DDL語句和不返回結果集的存儲過程調用。返回的int值是命令影響的數據庫行數。 |
ExecuteReader() | 其返回類型爲SqlDataReader, 執行SELECT語句、TableDirect命令或返回結果集的存儲過程調用。在SqlDataReader對象中返回結果集。 |
ExecuteScalar() | 其返回類型爲object,執行返回單個值的SELECT語句(任何其他的值將被忽略)。這個命令結果作爲對象被返回。 |
ExecuteXmlReader() | 其返回類型爲XmlReader,執行返回XML數據的SELECT語句,用XmlReader對象返回結果集,只適用於SqlCommand類 |
生成SqlCommand對象
我們可以用構造函數生成SqlCommand對象,也可以調用SqlConnection對象的CreateCommand()方法生成SqlCommand對象,下面分別介紹這兩種方法。
用構造函數生成SqlCommand對象
SqlCommand對象的構造函數如下所示:
SqlCommand() SqlCommand(string commandText) SqlCommand(string commandText,SqlConnection mySqlConnection) |
程序代碼說明:在上述語法範例的程序代碼中,commandText包含SQL語句、存儲過程調用或要讀取的表。mySqlConnection是對應的SqlConnection對象。
在使用SqlCommand對象之前,首先要確定一個SqlConnection對象,用於和SQL Server數據庫進行數據傳遞。
mySqlConnection.ConnectionString="server=localhost;database=Northwind; integrated security=SSPI"; |
然後可以用下列語句生成新的SqlCommand對象:
SqlCommand mySqlCommand=new SqlCommand(); |
再將mySqlCommand對象的Connection屬性設置爲mySqlConnection:
mySqlCommand.Connection= mySqlConnection; |
這樣mySqlCommand對象就可以使用mySqlConnection與數據庫進行數據傳遞。現在,Command對象的CommandType屬性確定要執行的命令類型。可以用System.Data.CommandType枚舉值指定CommandType屬性。
CommandType的枚舉值如下表所示:
數值 | 說明 |
Text | 表示命令是SQL語句,默認值是Text |
StoredProcedure | 表示命令是儲存過程調用 |
TableDirect | 表示被讀取的行和列的表名。注意:SqlCommand對象不支持TableDirect,要使用其他的Command類的對象。 |
例如你可以採用如下的形式執行一個SQL查詢:
SqlCommand mySqlCommand=new SqlCommand(); mySqlCommand.Connection=mySqlConnection; mySqlCommand.CommandText=”SELECT * FROM Employees”; //mySqlCommand.CommandType=CommandType.Text; |
程序代碼說明:在上述語法範例的程序代碼中,我們設置了mySqlCommand對象的commandText爲一個SELECT查詢語句,並且指定了mySqlCommand對象的CommandType屬性爲CommandType.Text,表示命令是SQL語句。由於CommandType.Text是默認的CommandType值,所以我們可以將其註譯掉。
還有一個更具效率的形式,那就是使用SqlCommand對象的其中一種構造函數:
SqlCommand mySqlCommand=new SqlCommand(”SELECT * FROM Employees”,myConnection); |
程序代碼說明:在上述語法範例的程序代碼中,我們可以直接利用SqlCommand(string commandText,SqlConnection mySqlConnection) 構造函數,從而使得程序代碼更加的簡練和直觀。
還可以使用儲存過程來查詢所需要的數據,我們可以採用如下的代碼形式:
SqlCommand mySqlCommand=new SqlCommand(”GetEmpolyees”,myConnection); mySqlCommand.CommandType=CommandType.StoredProcedure; |
程序代碼說明:在上述語法範例的程序代碼中,GetEmpolyees爲一個儲存過程名,用來實現所有的僱員信息查詢。並且將CommandType值指定爲StoredProcedure,表示命令是儲存過程調用。
使用CreateCommand()方法生成SqlCommand對象
如果不用構造函數,也可以使用SqlConnection對象的CreateCommand()方法生成SqlCommand對象。這個方法返回新的SqlCommand對象。例如:
SqlCommand mySqlCommand=mySqlConnection.CreateCommand(); |