DBNull.Value被保存为空字符串

时间:2013-11-15 11:32:06

标签: c# asp.net sql visual-studio

这是我的方法,此方法附加到附加到ASPXGridview的数据源。我的问题是,即使“语言”的“N / A”传递给此SP,有时在数据库中它会被保存为空字符串。这不会一直发生......

为什么这可能会被保存为空字符串的任何想法?

    public static void MaintainConfig(int ID, int ConfigVersionID, string Key, string Value, string Description, string Language)
    {
        SqlConnection conn = xxxServicesConnection();
        SqlCommand cmd = new SqlCommand("MaintainConfig", conn);
        cmd.CommandType = CommandType.StoredProcedure;

        cmd.Parameters.AddWithValue("@configID", ID);
        cmd.Parameters.AddWithValue("@configVersionID", ConfigVersionID);
        cmd.Parameters.AddWithValue("@key", Key);
        cmd.Parameters.AddWithValue("@value", Value);
        cmd.Parameters.AddWithValue("@desc", Description);
        if (Language == "N/A") //if the user wants to remove the language
        {
            cmd.Parameters.AddWithValue("@lang", DBNull.Value);
        }
        else
        {
            cmd.Parameters.AddWithValue("@lang", Language);
        }

        conn.Open();

        try
        {
            cmd.ExecuteNonQuery();
        }
        catch (SqlException sqlEx)
        {
            if (sqlEx.Number == 50000)
            {
                throw sqlEx;
            }
            else
            {
                throw new Exception("Database error occured");
            }
        }
        catch (Exception ex)
        {
            throw new Exception("Database error occured");
        }
        finally
        {
            conn.Close();
        }
    }

3 个答案:

答案 0 :(得分:0)

Language可能首先是空字符串。

if (Language == null)更改为if (string.IsNullOrEmpty(Language))

如果要排除空格,可以使用string.IsNullOrWhitespace()

答案 1 :(得分:0)

第1步:而不是使用NULL使用String.IsNullOrEmpty()功能进行比较。

替换为:

else if (Language == null)
        {
            cmd.Parameters.AddWithValue("@lang", DBNull.Value);
        }

以下内容:

else if (String.IsNullOrEmpty(Language.Trim()))
        {
            cmd.Parameters.AddWithValue("@lang", DBNull.Value);
        }

Step2:在比较之前修剪值:

替换为:

if (Language == "N/A") //if the user wants to remove the language
        {
            cmd.Parameters.AddWithValue("@lang", DBNull.Value);
        }

以下内容:

if (Language.Trim().Equals("N/A")) //if the user wants to remove the language
        {
            cmd.Parameters.AddWithValue("@lang", DBNull.Value);
        }

最终解决方案:如果字符串包含NULL,则Trim()  抛出异常因此在修剪值之前检查NULL

if (String.IsNullOrEmpty(Language))
{
cmd.Parameters.AddWithValue("@lang", DBNull.Value);
}

else if(Language.Trim().Equals("N/A"))
{
cmd.Parameters.AddWithValue("@lang", DBNull.Value);
}

else if(Language.Trim().Equals(""))
{
cmd.Parameters.AddWithValue("@lang", DBNull.Value);
}
else
{
cmd.Parameters.AddWithValue("@lang", Language);
}

答案 2 :(得分:0)

Language为空字符串时,它会保存为。

更改行

if (Language == null) 

if (String.IsNullOrEmpty(Language))