ExecuteScalar 返回值問題


DbCommand.ExecuteScalar 方法:

執行查詢,並返回查詢所返回的結果集中第一行的第一列。 所有其他的列和行將被忽略。
語法: public abstract Object ExecuteScalar() 返回值: 類型: System.Object,結果集中第一行的第一列。
備注: 使用 ExecuteScalar 方法從數據庫中檢索單個值(例如一個聚合值)。 與使用 ExecuteReader 方法然后使用 DbDataReader 返回的數據執行生成單個值所需的操作相比,此操作需要的代碼較少。如果找不到結果集中第一行的第一列;則返回 null 引用(在 Visual Basic 中為 Nothing)。 如果數據庫中的該值為 null,此查詢將返回 DBNull.Value。

  • 對於查詢單個字段,不包括函數的 select 語句,例如 select a字段 from 表A ,如果不存在值,DbCommand.ExecuteScalar 方法的返回值是 null,調用者需要使用 result == null 來判斷。
  • 對於使用函數的select 語句,例如select sum(a字段) from 表A,如果不存在值,DbCommand.ExceuteScalar 方法的返回值是 DBNull.Value,調用者需要用 result is DBNull 或者 result == DBNull.Value 來判斷。

對 ADO.NET 的 DbCommand.ExecuteScalar 方法的調用者來說,要注意根據所使用的 SQL 語句來選擇使用 result == null 還是使用 result is DBNull 來判斷查詢結果是否為空。如果使用 result == null || result is DBNull 來判斷查詢結果是否為空就更保險了,能夠適應這兩種 SQL 語句的寫法,但是運行效率會有所降低。


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM