Mybatis中各个方法

在 MyBatis 中,这四个方法都是用于执行数据库更新操作的,但是它们之间有些许区别:

  1. updateByExample

    • 这个方法会根据指定的条件来更新数据库中的记录。
    • 通常情况下,你需要提供一个对象作为更新的数据,以及一个示例对象(例如一个对象的属性作为查询条件),MyBatis会根据这个示例对象的条件去更新匹配的记录。
  2. updateByExampleSelective

    • 类似于 updateByExample,但是它只会更新对象中非空的字段。换句话说,如果对象中某个属性为null,那么对应的数据库字段就不会被更新。
  3. updateByPrimaryKey

    • 这个方法会根据给定的主键值来更新数据库中的记录。
    • 你需要提供一个完整的对象作为更新的数据,而不是一个示例对象。
  4. updateByPrimaryKeySelective

    • 类似于 updateByPrimaryKey,但是它只会更新对象中非空的字段。
    • 如果对象中某个属性为null,那么对应的数据库字段就不会被更新。

这些方法在不同的场景下有不同的用途。如果你想根据某个条件来更新记录,可以使用 updateByExample 系列方法。如果你已经有了对象的主键值,可以使用 updateByPrimaryKey 系列方法。而如果你只想更新对象中非空的字段,可以使用带有 Selective 后缀的方法。

相关推荐
你好,帅哥18 小时前
sqlcipher 编译
数据库
roman_日积跬步-终至千里18 小时前
【源码分析】StarRocks TRUNCATE 语句执行流程:从 SQL 到数据清空的完整旅程
java·数据库·sql
ClouGence18 小时前
从 0 到 1 构建 TDSQL MySQL 实时同步链路
数据库·分布式·sql·mysql
期待のcode18 小时前
MyBatis-Plus通用枚举
java·数据库·后端·mybatis·springboot
编织幻境的妖18 小时前
数据库物化视图与普通视图区别
数据库·oracle
进阶的DW18 小时前
测开平台(后端开发)
数据库
Hello.Reader18 小时前
Flink SQL 集合运算UNION / INTERSECT / EXCEPT 以及 IN / EXISTS 在流式场景下怎么用?
数据库·sql·flink
_Minato_19 小时前
数据库知识整理——数据库控制功能
数据库·经验分享·笔记·软考·计算机系统
TDengine (老段)19 小时前
TDengine 数据订阅架构设计与最佳实践
大数据·数据库·时序数据库·tdengine·涛思数据
Jtti19 小时前
MySQL磁盘不足会导致服务直接崩溃吗?
数据库·mysql