SqlCommand對NULL字段不進行更新真是怪!!

今天碰到個問題。。SqlCommand對傳送的參數中如果字段的值是NULL具然不進行更新操作,也不提示任何錯誤。。。百思不得其解。。。先作個記錄,再查資料看看什麼原因。

暫時的解決方法:

1、Update不支持更新Null,先Delete後Insert來替換.
2、替代Null的方法,對於字符型,只要是Null,改爲空,語句中就是''.

找到了相關的解決方法

ADO.Net的Command對象如何向數據庫插入NULL值(原創)
一般來說,在Asp.Net與數據庫的交互中,通常使用Command對象,如:SqlCommand。通過Command對象對數據庫操作是相當安全和方便的(相對於RecordSet方式)。但是,同時發現了一個問題。像有些日期字段,如果用戶沒有選擇日期,我們希望他保持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;

不過,還有一點要注意的就是,這裏的IsNullable,不是說你可以插入null值,而是指DBNull.Value值。

希望這點小經驗會對大家有幫助。
發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章