前几天遇到一个问题,找了好久才找到解决办法。不过也很开心,终于解决了。

问题:前端当我数据为空的时候不赋值,传到后台也为空的时候(注意:是Null不是""),SqlCommand对传送的参数中如果字段的值是NULL具然不进行更新操作。

插入、更新操作都不进行,现在咱们拿插入为例(更新同理)。

例:

  1. public bool Insert(SysNotify notify)
  2. {
  3. SqlParameter[] parameters = new SqlParameter[]
  4. {
  5.   new SqlParameter("@Title", notify.Title),
  6.   new SqlParameter("@NotifyType", notify.NotifyType),
  7.   new SqlParameter("@NotifyContent", notify.NotifyContent)
  8. };
  9.  
  10. string sqlStr = @" INSERT INTO SysNotify(Title, NotifyType, NotifyContent)
  11. VALUES(@Title, @NotifyType, @NotifyContent) ";
  12.  
  13. return DbHelper.ExecuteNonQuery(CommandType.Text, sqlStr, parameters);
  14. }

这里就是当notify.Title为Null时,就会报错,所以要对notify.Title这个字段处理一下。

解决办法:

我使用扩展方法封装了一个静态方法:

  1. #region 判断数据为空时,获取其DBNull的值 徐悦 2019年2月23日17:16:35
  2. /// <summary>
  3. /// 判断数据为空时,获取其DBNull的值
  4. /// </summary>
  5. /// <param name="value"></param>
  6. /// <returns></returns>
  7. public static object GetDBNull(this object value)
  8. {
  9. if (value == null)
  10.   {
  11. return DBNull.Value;
  12. }
  13. return value;
  14. }
  15. #endregion

然后按照下面这种形式调用就可以处理数据为空时的处理

  1. public bool Insert(SysNotify notify)
  2. {
  3. SqlParameter[] parameters = new SqlParameter[]
  4. {
  5.   new SqlParameter("@Title", notify.Title.GetDBNull()),
  6.   new SqlParameter("@NotifyType", notify.NotifyType),
  7.   new SqlParameter("@NotifyContent", notify.NotifyContent.GetDBNull())
  8. };
  9.  
  10. string sqlStr = @" INSERT INTO SysNotify(Title, NotifyType, NotifyContent)
  11. VALUES(@Title, @NotifyType, @NotifyContent) ";
  12.  
  13. return DbHelper.ExecuteNonQuery(CommandType.Text, sqlStr, parameters);
  14. }

按照标红处方式使用就可以解决当数据为空时,SqlCommond执行不成功的问题。

bingo(o゜▽゜)o☆[BINGO!]

C#:往数据库插入/更新时候关于NUll空值的处理的更多相关文章

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

    本文转载:http://blog.csdn.net/chybaby/article/details/2338943 本文转载:http://www.cnblogs.com/zfanlong1314/a ...

  2. DButils工具类能够用来获取数据库连接向数据库插入更新删除对象2

    package com.ctl.util; import java.awt.Color; import java.awt.Font; import java.awt.Insets; import ja ...

  3. Sql Server数据库使用触发器和sqlbulkcopy大批量数据插入更新

    需要了解的知识 1.触发器 2.sqlbulkcopy 我的用途 开发数据库同步的工具,需要大批量数据插入和数据更新. 方式 使用SqlBulkCopy类对数据进行数据批量复制,将需要同步数据的表新建 ...

  4. 数据库 插入时 碰到NULL报错判断的一种方法(技巧)

    //public static object ToDBNull(object value) 判断插入数据的时候个别参数不能为空的时候做的判断方法 //{ // if (value == null) / ...

  5. 【转】编写微信聊天机器人4《聊天精灵WeChatGenius》:实时获取到微信聊天消息,hook数据库插入操作。

    接上篇,使用Xposed来hook微信,找到微信进程:https://blog.csdn.net/weixin_42127613/article/details/81839537 既然已经找到了微信进 ...

  6. day38 mycql 初识概念,库(增删改查),表(增删改)以及表字段(增删改查),插入更新操作

    在Navicat中把已经生成的表逆向成模型 数据库上,右键-逆向数据库到模型 ego笔记: 增删改查 文件夹(库) 增 create database day43 charset utf8; 改 al ...

  7. MongoDB数据库中更新与删除数据

    MongoDB数据库中更新与删除数据 在MongoDB数据库中,可以使用Collection对象的update方法更新集合中的数据文档.使用方法如下所示: collection.update(sele ...

  8. MySQL_插入更新 ON DUPLICATE KEY UPDATE

    平时我们在设计数据库表的时候总会设计 unique  或者 给表加上 primary key 的限制条件. 此时 插入数据的时候 ,经常会有这样的情况: 我们想向数据库插入一条记录: 若数据表中存在以 ...

  9. 【SQL模板】四.插入/更新 列模板TSQL

    ---Name: 插入/更新 列模板.sql ---Purpose: 用于更新 数据库中 列 的脚本模板 ---Author: xx ---Time: 2015-12-18 10:26:06 ---R ...

随机推荐

  1. 微信小程序中转义字符的处理

    在微信小程序开发过程中,有时候会用到常用的一些特殊字符如:‘<’.‘>’.‘&’.‘空格’等,微信小程序同样支持对转义字符的处理,下面提供两种方法用来处理微信小程序中转义字符的处理 ...

  2. 零基础java的福音!史上最全最精简的学习路线图!

    这是一个java系统学习路线,从零基础到项目框架开发,每一个阶段里面内容都标记的很清楚,如果你现在也在学习java,你可以跟着这个系统学习路线学,学完自己可以独立的完成项目框架开发,二线城市拿个7k+ ...

  3. 解决MUI阻止a标签默认跳转事件—方法总结

    用过mui的小伙伴们一定不会陌生,有时候真的很烦mui本身会阻止a标签默认跳转.一般只要用了mui的ui组件,比如头部,底部或者弹框,你就不能在用a标签进行跳转了. 注:项目中引用了mui后,可能也会 ...

  4. PHP学习笔记 02 之文件上传

    我们了解了表单传值后,这些我就可以完成PHP的文件上传了.我们了解PHP文件上传前,先了解PHP文件上传的原理. 一.PHP上传文件原理 第一步:将本地的文件通过form表单上传到服务器的临时目录中, ...

  5. Scrapy-redis<数据库篇>

    scrapy-redis爬虫数据库连接部分——windows准备做salve,Linux准备做master开展工作 首先处理简单的windows熟悉的环境——安装Redis服务和Redis可视化~可视 ...

  6. 使用 Moq 测试.NET Core 应用 -- Mock 行为

    第一篇文章, 关于Mock的概念介绍: https://www.cnblogs.com/cgzl/p/9294431.html 第二篇文章, 关于方法Mock的介绍: https://www.cnbl ...

  7. MySQL配置参数说明

    MYSQL服务器my.cnf配置参数详解: 硬件:内存16G [client] port = 3306 socket = /data/mysql.sock [mysql] no-auto-rehash ...

  8. 使用EOLINKER做接口测试最佳路径(上)

    本文内容: 测试脚本管理:讲述如何在 EOLINKER 上设计测试项目目录结构. 编写测试脚本:讲述如何在 EOLINKER 上编写接口测试脚本. 测试脚本执行及报告:讲述如何在 EOLINKER 上 ...

  9. 【Java】留下没有基础眼泪的面试题

    前言 只有光头才能变强 本文力求简单讲清每个知识点,希望大家看完能有所收获 一.如何减少线程上下文切换 使用多线程时,不是多线程能提升程序的执行速度,使用多线程是为了更好地利用CPU资源! 程序在执行 ...

  10. 使用Atlas进行元数据管理之Type(类型)

    背景:笔者和团队的小伙伴近期在进行数据治理/元数据管理方向的探索, 在接下来的系列文章中, 会陆续与读者们进行分享在此过程中踩过的坑和收获. 元数据管理系列文章: [0] - 使用Atlas进行元数据 ...