Mybatis中各个方法

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

  1. updateByExample

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

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

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

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

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

相关推荐
Leo.yuan18 分钟前
不同数据仓库模型有什么不同?企业如何选择适合的数据仓库模型?
大数据·数据库·数据仓库·信息可视化·spark
麦兜*35 分钟前
MongoDB 6.0 新特性解读:时间序列集合与加密查询
数据库·spring boot·mongodb·spring·spring cloud·系统架构
chat2tomorrow38 分钟前
数据采集平台的起源与演进:从ETL到数据复制
大数据·数据库·数据仓库·mysql·低代码·postgresql·etl
稻草人想看远方41 分钟前
关系型数据库和非关系型数据库
数据库
考虑考虑41 分钟前
Postgerssql格式化时间
数据库·后端·postgresql
千里码aicood1 小时前
【springboot+vue】党员党建活动管理平台(源码+文档+调试+基础修改+答疑)
java·数据库·spring boot
TDengine (老段)1 小时前
TDengine 选择函数 Max() 用户手册
大数据·数据库·物联网·时序数据库·tdengine·涛思数据
驾驭人生1 小时前
Asp .Net Core 系列:Asp .Net Core 集成 Hangfire+MySQL
数据库·mysql·.netcore
xhbh6662 小时前
不止是DELETE:MySQL多表关联删除的JOIN语法实战详解
数据库·mysql·程序员·mysql删除语句