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

本文转载:http://blog.csdn.net/chybaby/article/details/2338943

今天碰到个问题。。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值。 希望这点小经验会对大家有帮助。

方法一、 
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);
        }

调用:
 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);
        }
调用:
 feedBackBLL.UpdateFeedBackStatus(_feedBackID, 4,null);

二、C#中往数据库插入空值的问题

在用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();

本文参与腾讯云自媒体分享计划,欢迎正在阅读的你也加入,一起分享。

发表于

我来说两句

0 条评论
登录 后参与评论

相关文章

来自专栏小樱的经验随笔

Codeforces 706B Interesting drink

B. Interesting drink time limit per test:2 seconds memory limit per test:256 meg...

30380
来自专栏青玉伏案

iOS开发之SQLite--C语言接口规范(四) —— Result Values From A Query

  数据库的在上一篇博客中《SQLite之C语言接口规范(三)——Binding Values To Prepared Statements》用到了如何从查询结...

204100
来自专栏Java编程技术

Mysql中使用流式查询避免数据量过大导致OOM-后续

之前http://www.jianshu.com/p/0339c6fe8b61 介绍了MySQL中三种使用流式方法,看起来很优雅,实则优雅的同时还是有一些注意事...

84110
来自专栏数据结构与算法

BZOJ4260: Codechef REBXOR (01Tire树)

10930
来自专栏恰童鞋骚年

Hadoop学习笔记—5.自定义类型处理手机上网日志

  假设我们如下一个日志文件,这个文件的内容是来自某个电信运营商的手机上网日志,文件的内容已经经过了优化,格式比较规整,便于学习研究。

8010
来自专栏青玉伏案

Oracle常用函数

前一段时间学习Oracle 时做的学习笔记,整理了一下,下面是分享的Oracle常用函数的部分笔记,以后还会分享其他部分的笔记,请大家批评指正。 1.Oracl...

21890
来自专栏IMWeb前端团队

Redux源码解析系列(四)-- combineReducers

本文作者:IMWeb 黄qiong 原文出处:IMWeb社区 未经同意,禁止转载 combindeReducer 字面意思就是用来合并reducer的...

20170
来自专栏Hongten

spring+hibernate+struts2+compass整合

http://www.cnblogs.com/hongten/gallery/image/113449.html

12540
来自专栏MasiMaro 的技术博文

OLEDB 静态绑定和数据转化接口

OLEDB 提供了静态绑定和动态绑定两种方式,相比动态绑定来说,静态绑定在使用上更加简单,而在灵活性上不如动态绑定,动态绑定在前面已经介绍过了,本文主要介绍OL...

12210
来自专栏程序员的SOD蜜

使用操作符重载,生成ORM实体类的SQL条件语句

ORM框架的一个不可或缺的功能就是根据实体类,生成操作数据库的SQL语句,这其中,最难处理的就是那些复杂的SQL条件比较语句。比如,有下面这样一个SQL语句: ...

236100

扫码关注云+社区

领取腾讯云代金券