首页 游戏 软件 资讯 排行榜 专题
首页
编程语言
tkmybatisupdate各种类型使用及说明

tkmybatisupdate各种类型使用及说明

热心网友
23
转载
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。

最新APP

宝宝过生日
宝宝过生日
应用辅助 04-07
台球世界
台球世界
体育竞技 04-07
解绳子
解绳子
休闲益智 04-07
骑兵冲突
骑兵冲突
棋牌策略 04-07
三国真龙传
三国真龙传
角色扮演 04-07

热门推荐

Ubuntu环境下如何调试Golang打包过程
编程语言
Ubuntu环境下如何调试Golang打包过程

在Ubuntu环境下调试Golang打包过程 在Ubuntu上折腾Go项目的打包和调试,是不少开发者都会经历的环节。这个过程其实并不复杂,只要按部就班,就能把问题理清楚。下面这几个步骤,算是经验之谈,能帮你快速定位和解决打包过程中的常见问题。 1 确保已安装Go环境 第一步,也是最基础的一步:确认

热心网友
04.24
Node.js在Linux系统中如何实现数据备份与恢复
编程语言
Node.js在Linux系统中如何实现数据备份与恢复

Node js 在 Linux 的数据备份与恢复实践 一 备份范围与策略 在动手之前,得先想清楚要保护什么。一个典型的 Node js 应用,需要备份的对象通常包括这几块: 明确备份对象:首先是应用代码与核心配置,它们通常位于类似 var www my_node_app 的目录下。别漏了依赖清单

热心网友
04.24
Golang在Ubuntu打包时如何排除文件
编程语言
Golang在Ubuntu打包时如何排除文件

Golang在Ubuntu打包时如何排除文件 在Golang项目里, gitignore文件大家都很熟悉,它负责在版本控制时过滤掉不需要的文件。但如果你遇到的问题是:在编译打包阶段,如何精准地排除某些源代码文件呢?这时候, gitignore就无能为力了。解决这个问题的关键,在于用好Go语言提供的“

热心网友
04.24
Ubuntu下Golang打包工具怎么选
编程语言
Ubuntu下Golang打包工具怎么选

在 Ubuntu 上为 Go 项目选择打包工具 为 Go 项目选择打包工具,这事儿说简单也简单,说复杂也复杂。关键得看你的交付目标是什么——是生成一个本机二进制文件就够,还是需要面向多平台发行、打包成容器镜像,甚至是制作成标准的 deb 系统包?同时,你的交付流程也至关重要,是本地手工操作,还是集

热心网友
04.24
Node.js在Linux环境下如何进行性能测试
编程语言
Node.js在Linux环境下如何进行性能测试

Node js 在 Linux 环境下的性能测试与瓶颈定位 一、测试流程与准备 性能测试不是一场盲目的冲锋,而是一次精密的实验。一切始于清晰的目标和稳定的环境。 明确目标与指标:首先,得把目标量化。是要求P95延迟稳定在200毫秒以内,还是错误率必须低于0 5%?把这些数字定下来。紧接着,锁定测试环

热心网友
04.24