日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當(dāng)前位置: 首頁 > 编程语言 > C# >内容正文

C#

C#中往数据库插入/更新时候关于NUll空值的处理

發(fā)布時(shí)間:2023/12/13 C# 25 豆豆
生活随笔 收集整理的這篇文章主要介紹了 C#中往数据库插入/更新时候关于NUll空值的处理 小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,幫大家做個(gè)參考.

?

本文轉(zhuǎn)載:http://blog.csdn.net/chybaby/article/details/2338943

?

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

暫時(shí)的解決方法:

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

找到了相關(guān)的解決方法

ADO.Net的Command對象如何向數(shù)據(jù)庫插入NULL值(原創(chuàng)) 一般來說,在Asp.Net與數(shù)據(jù)庫的交互中,通常使用Command對象,如:SqlCommand。通過Command對象對數(shù)據(jù)庫操作是相當(dāng)安全和方便的(相對于RecordSet方式)。但是,同時(shí)發(fā)現(xiàn)了一個(gè)問題。像有些日期字段,如果用戶沒有選擇日期,我們希望他保持NULL狀態(tài)。我寫的關(guān)鍵代碼如下:

SqlCommand sqlCmd = new SqlCommand(sqlStatment, dbConn);
sqlCmd.Parameters.AddWithValue("@Name", name);
sqlCmd.Parameters.AddWithValue("@Surname", surname);

這時(shí),雖未出錯(cuò),但返回的影響行數(shù)告訴我。更新未成功。這是怎么回事呢?
原來ADO.Net為了防止一些不容易找出的錯(cuò)誤,在Command操作時(shí)加了一些限制。我們必須明確指示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;

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

希望這點(diǎn)小經(jīng)驗(yàn)會對大家有幫助。 方法一、? public?int?UpdateFeedBackStatus(int?_feedBackID,?int?_status,?object?_RequestDateTime)
????????{
????????????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);
????????}


調(diào)用:
?feedBackBLL.UpdateFeedBackStatus(_feedBackID,?4,?DBNull.Value); 或者feedBackBLL.UpdateFeedBackStatus(_feedBackID, 4,null); 方法二: public?int?UpdateFeedBackStatus(int?_feedBackID,?int?_status,?DateTime??_RequestDateTime)
????????{
????????????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);
????????} 調(diào)用:
?feedBackBLL.UpdateFeedBackStatus(_feedBackID, 4,null);

?

二、C#中往數(shù)據(jù)庫插入空值的問題

在用C#往數(shù)據(jù)庫里面插入記錄的時(shí)候,?可能有的字段你不賦值,那么這個(gè)字段的值就為null,?如果按一般想法的話,這個(gè)值會被數(shù)據(jù)庫接受,?然后在數(shù) 據(jù)表里面顯示為NUll,?實(shí)際上這就牽扯到一個(gè)類型的問題,?C#中的NUll于SQL中的null是不一樣的,?SQL中的null用C#表示出來就 是DBNull.Value,?所以在進(jìn)行Insert的時(shí)候要注意的地方.

Example:
???????SqlCommand?cmd=new??SqlCommand("Insert?into?Student?values(@StuName,@StuAge)"?,con);
???????cmd.parameters.add("@StuName"?,stuname);
???????cmd.parameters.add("@StuAge"?,stuage);
???????cmd.ExecuteNonQuery();

這些代碼看似沒有問題,?其實(shí)當(dāng)stuname于stuage中的任何一個(gè)值為null的時(shí)候,?這代碼就會報(bào)錯(cuò)...汗!!!

解決辦法:

????????其實(shí)最簡單的辦法就是進(jìn)行判斷,?當(dāng)stuname或stuage為空時(shí),?插入DBNull.Value.
????????但是這樣當(dāng)一個(gè)數(shù)據(jù)庫有很多字段時(shí)或者是有很多張表時(shí),?代碼就會很多了,我也沒有找到特別方便的方法,我的方法是:寫一個(gè)靜態(tài)的方法來對變量的值進(jìn)行判斷:

Example?:?????

????????static??public??object??SqlNull(object??obj)
????????{
????????????if??(obj?==?null?)
????????????????return??DBNull.Value;

????????????return??obj;
????????}

???????//用上面的方法對參數(shù)進(jìn)行了判斷?
???????cmd.parameters.add("@StuName"?,SqlNull(stuname));
???????cmd.parameters.add("@StuAge"?,SqlNull(stuage));
???????cmd.ExecuteNonQuery();

轉(zhuǎn)載于:https://www.cnblogs.com/51net/p/3243533.html

總結(jié)

以上是生活随笔為你收集整理的C#中往数据库插入/更新时候关于NUll空值的处理的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網(wǎng)站內(nèi)容還不錯(cuò),歡迎將生活随笔推薦給好友。