我需要检查我的存储过程是否返回null值。 目前我有以下代码:
public static bool MyMethod(String isoNum)
{
SqlConnection conn = null;
bool regionExists = true;
try
{
using (conn = new SqlConnection(ConfigurationManager.ConnectionStrings["String"].ConnectionString))
{
using (SqlCommand cmd = new SqlCommand("SPU_GetRegionBasedOnIso", conn))
{
cmd.CommandType = CommandType.StoredProcedure;
cmd.Parameters.AddWithValue("@isoNum", isoNum);
using (SqlDataReader dr = cmd.ExecuteReader())
{
**<<Here I need to check for NULL value>>**
}
}
}
}
catch (Exception e)
{
throw new System.Exception(e.Message.ToString());
}
return regionExists;
}
这里检查NULL的最佳方法是什么?
谢谢
答案 0 :(得分:2)
使用ExecuteScalar
代替ExecuteReader
,并与DBNull.Value
进行比较。
object result = cmd.ExecuteScalar();
if (result == DBNull.Value)
{
....
}