本文轉載:http://blog.csdn.net/chybaby/article/details/2338943
本文轉載:http://www.cnblogs.com/zfanlong1314/archive/2013/08/07/3243533.html
今天碰到個問題。。SqlCommand對傳送的參數中如果字段的值是NULL具然不進行更新操作,也不提示任何錯誤。。。百思不得其解。。。先作個記錄,再查資料看看什么原因。
暫時的解決方法:
1、Update不支持更新Null,先Delete后Insert來替換.
2、替代Null的方法,對於字符型,只要是Null,改為空,語句中就是''.
找到了相關的解決方法
SqlCommand sqlCmd = new SqlCommand(sqlStatment, dbConn);
sqlCmd.Parameters.AddWithValue("@Name", name);
sqlCmd.Parameters.AddWithValue("@Surname", surname);
原來ADO.Net為了防止一些不容易找出的錯誤,在Command操作時加了一些限制。我們必須明確指示Command對象,我們需要插入NUll值。修改后的代碼如下:
SqlCommand sqlCmd = new SqlCommand(sqlStatment, dbConn);
sqlCmd.Parameters.AddWithValue("@Name", name);
sqlCmd.Parameters.AddWithValue("@Surname", surname);
sqlCmd.Parameters[0].IsNullable = true;
sqlCmd.Parameters[1].IsNullable = true;
希望這點小經驗會對大家有幫助。
{
SqlParameter[] param = {
new SqlParameter("@FeedBackID", _feedBackID),
new SqlParameter("@FeedBackStatusID", _status),
new SqlParameter("@RequestDateTime", _RequestDateTime)
};
StringBuilder strSql = new StringBuilder();
strSql.Append("UPDATE dbo.FeedBack ");
strSql.Append("SET FeedBackStatusID=@FeedBackStatusID,RequestDateTime=@RequestDateTime ");
strSql.Append("WHERE FeedBackID=@FeedBackID ");
return DbHelper.ExecuteNonQuery(CommandType.Text,strSql.ToString(),param);
}
調用:
feedBackBLL.UpdateFeedBackStatus(_feedBackID, 4, DBNull.Value);
{
SqlParameter[] param = {
new SqlParameter("@FeedBackID", _feedBackID),
new SqlParameter("@FeedBackStatusID", _status),
new SqlParameter("@RequestDateTime", _RequestDateTime)
};
param[2].IsNullable = true;
StringBuilder strSql = new StringBuilder();
strSql.Append("UPDATE dbo.FeedBack ");
strSql.Append("SET FeedBackStatusID=@FeedBackStatusID,RequestDateTime=@RequestDateTime ");
strSql.Append("WHERE FeedBackID=@FeedBackID ");
return DbHelper.ExecuteNonQuery(CommandType.Text,strSql.ToString(),param);
}
feedBackBLL.UpdateFeedBackStatus(_feedBackID, 4,null);
在用C#往數據庫里面插入記錄的時候, 可能有的字段你不賦值,那么這個字段的值就為null, 如果按一般想法的話,這個值會被數據庫接受, 然后在數 據表里面顯示為NUll, 實際上這就牽扯到一個類型的問題, C#中的NUll於SQL中的null是不一樣的, SQL中的null用C#表示出來就 是DBNull.Value, 所以在進行Insert的時候要注意的地方.
Example:
SqlCommand cmd=new SqlCommand("Insert into Student values(@StuName,@StuAge)" ,con);
cmd.parameters.add("@StuName" ,stuname);
cmd.parameters.add("@StuAge" ,stuage);
cmd.ExecuteNonQuery();
這些代碼看似沒有問題, 其實當stuname於stuage中的任何一個值為null的時候, 這代碼就會報錯...汗!!!
解決辦法:
其實最簡單的辦法就是進行判斷, 當stuname或stuage為空時, 插入DBNull.Value.
但是這樣當一個數據庫有很多字段時或者是有很多張表時, 代碼就會很多了,我也沒有找到特別方便的方法,我的方法是:寫一個靜態的方法來對變量的值進行判斷:
Example :
static public object SqlNull(object obj)
{
if (obj == null )
return DBNull.Value;
return obj;
}
//用上面的方法對參數進行了判斷
cmd.parameters.add("@StuName" ,SqlNull(stuname));
cmd.parameters.add("@StuAge" ,SqlNull(stuage));
cmd.ExecuteNonQuery();