sqlserver数据可空插入报错

 

数据库和C#中均为可空类型。
这时候直接给字段赋值为null
parameters[9].Value = null ; 
执行的时候报错了,一大堆,总之说它少了一个参数。
用sql server profiler 工具查看执行代码 以下图:
 

    

这时候才找到缘由:     C#中赋值为null的字段到了数据库执行变成了default。
下面是解决方案:
加一个判断:当字段的值为null时,赋值为DBNull.Value。
parameters[9].Value = model.RedoDate == null ? (object)DBNull.Value : model.RedoDate;  
相关文章
相关标签/搜索