SqlCommand.ExecuteNonQuery 方法
對連接執行 Transact-SQL 語句並返回受影響的行數。
――語法:
public override int ExecuteNonQuery()
――返回值
類型:System..::.Int32
受影響的行數。
――可以使用 ExecuteNonQuery 來執行目錄操作(例如查詢數據庫的結構或創建諸如表等的數據庫對象),或通過執行 UPDATE、INSERT 或 DELETE 語句,在不使用 DataSet 的情況下更改數據庫中的數據。
雖然 ExecuteNonQuery 不返回任何行,但映射到參數的任何輸出參數或返回值都會用數據進行填充。
對於 UPDATE、INSERT 和 DELETE 語句,返回值為該命令所影響的行數。如果正在執行插入或更新操作的表上存在觸發器,則返回值包括受插入或更新操作影響的行數以及受一個或多個觸發器影響的行數。對於所有其他類型的語句,返回值為 -1。如果發生回滾,返回值也為 -1。
SqlCommand. ExecuteScalar 方法
執行查詢,並返回查詢所返回的結果集中第一行的第一列。忽略其他列或行。
――語法:
public override Object ExecuteScalar()
――返回值
類型:System.Object
結果集中第一行的第一列;如果結果集為空,則為空引用(在 Visual Basic 中為 Nothing)。
――使用 ExecuteScalar 方法從數據庫中檢索單個值(例如一個聚合值)。與使用 ExecuteReader 方法,然后使用 SqlDataReader 返回的數據執行生成單個值所需的操作相比,此操作需要的代碼較少。
――典型的 ExecuteScalar 查詢可以采用類似於下面的 C# 示例的格式:
cmd.CommandText = "SELECT COUNT(*) FROM dbo.region";
Int32 count = (Int32) cmd.ExecuteScalar();
SqlCommand.ExecuteReader 方法
將 CommandText 發送到 Connection 並生成一個 SqlDataReader。
――語法:
public SqlDataReader ExecuteReader()
――返回值
類型:System.Data.SqlClient..::.SqlDataReader
一個 SqlDataReader 對象。
——示例:
下面的示例創建一個 SqlCommand,然后通過傳遞兩個字符串來執行它,其中一個字符串是 Transact-SQL SELECT 語句,另一個字符串用於連接至數據源。
1 private static void CreateCommand(string queryString, 2 string connectionString) 3 { 4 using (SqlConnection connection = new SqlConnection( 5 connectionString)) 6 { 7 connection.Open(); 8 9 SqlCommand command = new SqlCommand(queryString, connection); 10 SqlDataReader reader = command.ExecuteReader(); 11 while (reader.Read()) 12 { 13 Console.WriteLine(String.Format("{0}", reader[0])); 14 } 15 } 16 }