一区二区三区在线-一区二区三区亚洲视频-一区二区三区亚洲-一区二区三区午夜-一区二区三区四区在线视频-一区二区三区四区在线免费观看

服務(wù)器之家:專注于服務(wù)器技術(shù)及軟件下載分享
分類導(dǎo)航

PHP教程|ASP.NET教程|Java教程|ASP教程|編程技術(shù)|正則表達式|C/C++|IOS|C#|Swift|Android|VB|R語言|JavaScript|易語言|vb.net|

服務(wù)器之家 - 編程語言 - C# - C#中SQL參數(shù)傳入空值報錯解決方案

C#中SQL參數(shù)傳入空值報錯解決方案

2022-01-07 13:35邪心魔佛一頁書 C#

這篇文章主要介紹了C#中SQL參數(shù)傳入空值報錯解決方案,需要的朋友可以參考下

C#中的null與SQL中的NULL是不一樣的,SQL中的NULL用C#表示出來就是DBNull.Value。

注意:SQL參數(shù)是不能接受C#的null值的,傳入null就會報錯。

下面我們看個例子:

?
1
2
3
4
SqlCommand cmd=new SqlCommand("Insert into Student values(@StuName,@StuAge)" ,conn);
cmd.parameters.add("@StuName" ,stuName);
cmd.parameters.add("@StuAge" ,stuAge);
cmd.ExecuteNonQuery();

上述代碼咋看冇問題,其實當stuName或stuAge的值為null時,就會拋出異常。那怎么解決呢?

解決方案:當stuName或stuAge的值為null時,傳入DBNull.Value。下面在公共類里寫一個靜態(tài)的通用方法對傳入的參數(shù)值進行判斷,為null則返回DBNull.Value,否則返回原值。

?
1
2
3
4
5
6
7
8
9
10
11
public static object SqlNull(object obj)
 {
  if(obj == null)
  {
   return DBNull.Value;
  }
  else
  {
   return obj;
  
 }

調(diào)用上述方法后的代碼如下:

?
1
2
3
4
SqlCommand cmd=new SqlCommand("Insert into Student values(@StuName,@StuAge)" ,conn);
cmd.parameters.add("@StuName" ,SqlNull(stuName));
cmd.parameters.add("@StuAge" ,SqlNull(stuAge));
cmd.ExecuteNonQuery();

另外,如果參數(shù)值來源于控件(如文本框)的值,則傳入的參數(shù)值不會為null(因為控件的值不會為null,即便沒值也是""),如果想實現(xiàn)當控件的值為""(如文本框中沒有輸入字符)時,數(shù)據(jù)表字段值為NULL,只需對SqlNull方法稍作修改:

?
1
2
3
4
5
6
7
8
9
10
11
public static object SqlNull(object obj)
{
  if(obj == null || obj.ToString() == "")
  {
   return DBNull.Value;
  }
  else
  {
   return obj;
 
}

延伸:

傳SQL參數(shù)還可以傳參數(shù)組,如下:

?
1
2
3
4
5
6
7
8
9
10
SqlParameter[] parm = new SqlParameter[]
{
 new SqlParameter("@StuName", SqlNull(stuName)),
 new SqlParameter("@StuAge", SqlNull(stuAge))
}
if(parm != null)
{
 cmd.Parameters.AddRange(parm); 
}
cmd.ExecuteNonQuery();

注意:new SqlParameter(參數(shù)名, 參數(shù)值)里的參數(shù)值同樣不接受null值,且parm參數(shù)組也不接受null, if(parm != null) 的判斷不能少。

以上所述是小編給大家介紹的C#中SQL參數(shù)傳入空值報錯解決方案,希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時回復(fù)大家的。在此也非常感謝大家對服務(wù)器之家網(wǎng)站的支持!

原文鏈接:http://www.cnblogs.com/Scl891004X/archive/2017/06/08/6962113.html

延伸 · 閱讀

精彩推薦
主站蜘蛛池模板: 精品女同一区二区三区免费站 | 性关系视频网站 | 狠狠综合久久综合网站 | 国产福利在线观看永久视频 | 精品无人区一区二区三区 | 网友偷自拍原创区 | sihu国产午夜精品一区二区三区 | 欧美操屁股| xxxxx性bbbbb欧美| 国产理论片在线观看 | 国产有码在线 | 99久久爱热6在线播放 | 国产精品亚洲午夜不卡 | 爽好舒服使劲添高h视频 | 亚洲AV 无码AV 中文字幕 | 无人区乱码1区2区3区网站 | 盲井在线| 日本伊人色综合网 | 亚洲高清国产品国语在线观看 | 国产伦精品一区二区三区女 | 91污无限制破解安卓2021 | 小黄鸭YELLOWDUCK7596| 美女视频黄a | 欧美一区二区三区gg高清影视 | 娇妻被健身教练挺进小说阅读 | 青青91 | 四虎精品免费国产成人 | 免费观看全集 | 熟睡迷j系列小说 | 99r视频| 精品国产成人a区在线观看 精品国产91久久久久久久 | 亚洲 日本 天堂 国产 在线 | 日本强不卡在线观看 | 黑人与老女人做受 | 新影音先锋男人色资源网 | 女学生被老师调教在教室 | 久久这里只有精品视频9 | 精选国产AV精选一区二区三区 | 亚洲国产精品综合久久网络 | 456亚洲老头视频 | 亚洲香蕉网久久综合影院3p |