当前位置: 首页
编程语言
tkmybatisupdate各种类型使用及说明

tkmybatisupdate各种类型使用及说明

热心网友 时间:2026-04-24
转载

1.updateByExample

先来看第一种情况:你需要根据一个给定的条件(Example)来更新数据,并且要求更新对象里的所有属性,包括主键ID。这意味着,你传给方法的实体对象,每一个字段都必须有值。

免费影视、动漫、音乐、游戏、小说资源长期稳定更新! 👉 点此立即查看 👈

tkmybatisupdate各种类型使用及说明

怎么用呢?看下面的代码示例就明白了:

package com.bsx.test;
public class Test {
    private int id;
    private String name;
    public int getId() {
        return id;
    }
    public void setId(int id) {
        this.id = id;
    }
    public String getName() {
        return name;
    }
    public void setName(String name) {
        this.name = name;
    }
}
Example example = new Example(Test.class);
example.createCriteria().andEqualTo("name", "test");
Test record = new Test();
record.setName("hello");
mapper.updateByExample(record, example);

这段代码执行后,最终生成的SQL语句是这样的:

UPDATE o2o_video_file  SET id = ?,name = ? WHERE (  name = ? )

看到了吗?它会用record对象里所有的值(id和name)去更新,而更新的范围则由example条件(这里是name=‘test’)来限定。这里有个关键点:即使你只想改name,id字段也必须设值,否则可能会产生非预期的结果。

2.updateByExampleSelective

那么,如果我只想更新部分字段,其他的保持原样,该怎么办?这就是updateByExampleSelective的用武之地了。它同样根据条件(Example)更新,但只会更新你传入对象中有值的属性

Example example = new Example(Test.class);
example.createCriteria().andEqualTo("name", "test");
Test record = new Test();
record.setName("hello");
mapper.updateByExampleSelective(record, example);

看看它解析出来的SQL:

UPDATE o2o_video_file  SET name = ? WHERE (  name = ? )

对比一下就很清楚了。因为record对象里只设置了name属性,所以生成的SET语句里就只有name字段。这种方式在部分更新时非常灵活,也更能避免误操作。

3.updateByPrimaryKey

接下来看基于主键的更新。updateByPrimaryKey这个方法顾名思义:根据主键来更新数据,并且是更新所有属性

Test record = new Test();
record.setId(123);
record.setName("hello");
mapper.updateByPrimaryKey(record, example);

其对应的SQL语句如下:

UPDATE o2o_video_file  SET id=?, name = ? WHERE (  id = ? )

注意,这里WHERE条件直接用的是主键ID。和使用Example条件更新不同,这种方式定位记录更精确,效率也通常更高。当然,同样的,你需要确保更新对象的所有属性都被正确赋值。

4.updateByPrimaryKeySelective

最后,也是最常用的一种组合:根据主键,只更新有值的属性。这就是updateByPrimaryKeySelective

Test record = new Test();
record.setId(123);
record.setName("hello");
mapper.updateByPrimaryKey(record, example);

看看生成的SQL,是不是感觉清爽多了?

UPDATE o2o_video_file  SET name = ? WHERE (  id = ? )

因为你只设置了id和name,所以它只会更新name字段。这在日常开发中处理“修改某几个字段”的场景时,简直是神器,既能完成需求,又避免了全字段覆盖可能带来的数据风险。

总结

简单梳理一下:TkMybatis提供的这四种更新方式,其实核心区别就在两点:按条件更新还是按主键更新,以及更新全部字段还是只更新有值字段

掌握它们之间的差异,就能在合适的场景选用最合适的方法,让代码既清晰又高效。希望上面的梳理和对比能给你带来清晰的参考。当然,实践出真知,多上手试试感受会更深刻。

您可能感兴趣的文章:

  • mybatis 获取更新(update)记录的id之用法说明
  • tk.mybatis通用插件updateByPrimaryKeySelective无法自动更新列的解决办法
来源:https://www.jb51.net/program/362785m6h.htm

游乐网为非赢利性网站,所展示的游戏/软件/文章内容均来自于互联网或第三方用户上传分享,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系youleyoucom@outlook.com。

同类文章
更多
Debian Java远程控制如何操作

Debian Java远程控制如何操作

Debian Ja va远程控制的常用方式与操作要点 对于需要在Ja va环境中远程管理Debian服务器的开发者来说,掌握几种核心的远程控制方式至关重要。这不仅能提升运维效率,也是构建分布式应用的基础能力。下面,我们就来梳理一下几种主流方案及其操作要点。 一、SSH与JSch远程执行与文件传输 先

时间:2026-04-24 18:44
Debian Compton如何与其他图形工具协同

Debian Compton如何与其他图形工具协同

Debian 下 Compton 与图形工具的协同指南 一 基础认知与适用场景 首先得明确一点:Compton 是专为 X11 设计的窗口合成器,它的本职工作就是处理窗口的合成、阴影、透明度这些视觉效果。这就意味着,它必须运行在 Xorg 会话下,无法直接用在 Wayland 上。如果你用的是 GN

时间:2026-04-24 18:42
Ubuntu上PyTorch与其他框架如何对比

Ubuntu上PyTorch与其他框架如何对比

Ubuntu上 PyTorch 与其他框架对比 面对众多深度学习框架,在Ubuntu上做选择时,你是不是也感到过一丝纠结?别担心,这份对比指南,或许能帮你快速理清思路。 一 快速选择建议 先说几个核心判断,帮你直接定位: 如果你的重心是研究原型、LLM 多模态,并且需要灵活调试与快速迭代:优先选择

时间:2026-04-24 18:42
如何利用Filebeat进行日志备份

如何利用Filebeat进行日志备份

Filebeat日志备份与保留策略 核心概念与总体思路 首先得明确一点:Filebeat的核心职责是“采集与转发”日志,它本身并不负责长期存储。换句话说,它是个高效的搬运工,而不是仓库管理员。那么,真正的“备份”和“保留”工作,得在它的下游环节来完成。 通常的做法是,将日志发送到Elasticsea

时间:2026-04-24 18:42
如何通过Filebeat进行故障排查

如何通过Filebeat进行故障排查

Filebeat故障排查实操指南 处理Filebeat的疑难杂症,最怕的就是东一榔头西一棒槌,没有章法。其实,一套清晰的排查流程,往往能让你事半功倍。下面这份指南,就为你梳理出一条从快速定位到深度解决的路径。 一 快速定位流程 当发现日志数据流中断时,别急着翻配置文件,先按这个“五步法”走一遍,大多

时间:2026-04-24 18:42
热门专题
更多
刀塔传奇破解版无限钻石下载大全 刀塔传奇破解版无限钻石下载大全
洛克王国正式正版手游下载安装大全 洛克王国正式正版手游下载安装大全
思美人手游下载专区 思美人手游下载专区
好玩的阿拉德之怒游戏下载合集 好玩的阿拉德之怒游戏下载合集
不思议迷宫手游下载合集 不思议迷宫手游下载合集
百宝袋汉化组游戏最新合集 百宝袋汉化组游戏最新合集
jsk游戏合集30款游戏大全 jsk游戏合集30款游戏大全
宾果消消消原版下载大全 宾果消消消原版下载大全
  • 日榜
  • 周榜
  • 月榜
热门教程
更多
  • 游戏攻略
  • 安卓教程
  • 苹果教程
  • 电脑教程