广告
返回顶部
首页 > 资讯 > 数据库 >sql语句 update字段null不能用is null问题
  • 297
分享到

sql语句 update字段null不能用is null问题

2024-04-02 19:04:59 297人浏览 八月长安
摘要

目录sql语句 update字段null不能用is nullupdate更新数据时null字段是否更新进数据库总结情况一:不需要更新进数据库情况二:需要更新进数据库 (推荐方法3)sql语句 update字段null不能

sql语句 update字段null不能用is null

update字段为 null 值时,

要用 

set column = null,

而不是

set column is null

✖ UPDATE tableA set 字段a is null WHERE字段b = 条件; 

例:

Mysql> UPDATE t SET col3 is null WHERE col1 = 'a';
ERROR 1064 (42000): You have an error in your SQL syntax; check the manual that corresponds to your MySQL Server version for the right syntax to use near 'is null WHERE col1 = 'a'' at line 1

〇 UPDATE tableA set 字段a = null WHERE字段b = 条件;

例:

mysql> UPDATE t SET col3 =  null WHERE col1 = 'a';
Query OK, 1 row affected (0.03 sec)

update更新数据时null字段是否更新进数据库总结

情况一:不需要更新进数据库

方法1:直接用sql语句方式,需要更新哪个字段就set xxclounm 即可

方法2:使用mybatis带的方法 updateById(Entry entry),传入entry对象只设置需要更新字段即可。

解析:mybatis-plus在update时对null字段有三种处理策略分别是:

  • IGNORED:0 忽略
  • NOT_NULL:1 非 NULL,默认策略
  • NOT_EMPTY:2 非空

默认策略是忽略null字段,所以只需要将entry中不需要更新的字段不做处理即可。注意:如果entry中字段设置为空字符串" " 则会更新进数据库

方法3:使用updateWapper,其实和方法2原理一样 如下例子只更新age字段 ,同样受更新策略影响:

UpdateWrapper<User> updateWrapper = new UpdateWrapper<>();
updateWrapper.eq("name","rhb");
User user = new User();
user.setAge(18);
userMapper.update(user, updateWrapper);

情况二:需要更新进数据库 (推荐方法3)

方法1:直接用sql语句方式,需要更新哪个字段就set xxclounm 即可

方法2:使用mybatis带的方法 updateById(Entry entry),传入entry对象只设置需要更新字段即可。另外在entry类中需要更新null的字段上加上注解updateStrategy 如下面例子:

  
  @TableField(value = "UNIT", updateStrategy = FieldStrategy.IGNORED)
  private String unit;

或者设置全局更新策略(按需要设置单个字段或者全局)

# yml配置
mybatis-plus:
 global-config:
  db-config:
   field-strategy: not_empty

方法3:使用updateWapper,不受更新策略影响。推荐此方法,设置完策略后别人在不知情情况下可能会在不想设置null时将你设置的字段更新为空

LambdaUpdateWrapper<User> lambdaUpdateWrapper = new LambdaUpdateWrapper<>();
lambdaUpdateWrapper.eq(User::getName, "rhb").set(User::getAge, null);
Integer rows = userMapper.update(null, lambdaUpdateWrapper);

以上为个人经验,希望能给大家一个参考,也希望大家多多支持我们。

您可能感兴趣的文档:

--结束END--

本文标题: sql语句 update字段null不能用is null问题

本文链接: https://www.lsjlt.com/news/34211.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
  • sql语句 update字段null不能用is null问题
    目录sql语句 update字段null不能用is nullupdate更新数据时null字段是否更新进数据库总结情况一:不需要更新进数据库情况二:需要更新进数据库 (推荐方法3)sql语句 update字段null不能...
    99+
    2022-09-26
  • sql语句update字段null不能用isnull问题
    目录sql语句 update字段null不能用is nullupdate更新数据时null字段是否更新进数据库总结情况一:不需要更新进数据库情况二:需要更新进数据库 (推荐方法3)s...
    99+
    2022-11-13
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作