这是我的方法,此方法附加到附加到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();
}
}
答案 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))