您的位置:首页 >tkmybatisupdate各种类型使用及说明
发布于2026-04-24 阅读(0)
扫一扫,手机访问
先来看第一种情况:你需要根据一个给定的条件(Example)来更新数据,并且要求更新对象里的所有属性,包括主键ID。这意味着,你传给方法的实体对象,每一个字段都必须有值。

怎么用呢?看下面的代码示例就明白了:
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字段也必须设值,否则可能会产生非预期的结果。
那么,如果我只想更新部分字段,其他的保持原样,该怎么办?这就是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字段。这种方式在部分更新时非常灵活,也更能避免误操作。
接下来看基于主键的更新。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条件更新不同,这种方式定位记录更精确,效率也通常更高。当然,同样的,你需要确保更新对象的所有属性都被正确赋值。
最后,也是最常用的一种组合:根据主键,只更新有值的属性。这就是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提供的这四种更新方式,其实核心区别就在两点:按条件更新还是按主键更新,以及更新全部字段还是只更新有值字段。
掌握它们之间的差异,就能在合适的场景选用最合适的方法,让代码既清晰又高效。希望上面的梳理和对比能给你带来清晰的参考。当然,实践出真知,多上手试试感受会更深刻。
您可能感兴趣的文章:
售后无忧
立即购买>office旗舰店
售后无忧
立即购买>office旗舰店
售后无忧
立即购买>office旗舰店
售后无忧
立即购买>office旗舰店
正版软件
正版软件
正版软件
正版软件
正版软件
1
2
3
7
9