如何检查从存储过程返回的NULL?

时间:2014-04-14 22:41:55

标签: c# sql sql-server stored-procedures null

我需要检查我的存储过程是否返回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的最佳方法是什么?

谢谢

1 个答案:

答案 0 :(得分:2)

使用ExecuteScalar代替ExecuteReader,并与DBNull.Value进行比较。

object result = cmd.ExecuteScalar();
if (result == DBNull.Value)
{
    ....
}