文章详情

短信预约-IT技能 免费直播动态提醒

请输入下面的图形验证码

提交验证

短信预约提醒成功

Fluent Mybatis中Update语法怎么用

2023-06-21 20:34

关注

小编给大家分享一下Fluent Mybatis中Update语法怎么用,希望大家阅读完这篇文章之后都有所收获,下面让我们一起去探讨吧!

数据准备

还是用之前在数据库存的数据,数据如下:

Fluent Mybatis中Update语法怎么用

Update语法

简单的写法

fm的update简单写法可以直接使用is()来对表字段进行赋值,如果需要将字段设置为Null的话,直接使用isNull()方法。

接口层代码添加

Integer updateSimple();

实现类代码添加

@Overridepublic Integer updateSimple() {  return testFluentMybatisMapper.updateBy(      new TestFluentMybatisUpdate()          .set          .name()          .is("何九")          .set          .age()          .isNull()          .end()          .where          .id()          .eq(2)          .end());}

控制层代码添加

@Autowired private IUpdateService updateService; @ApiOperation(value = "简单语法", notes = "简单语法")@RequestMapping(value = "/simple", method = RequestMethod.GET)@ResponseBodypublic Result<Integer> updateSimple() {  try {    return Result.ok(updateService.updateSimple());  } catch (Exception exception) {    return Result.error(ErrorCode.BASE_ERROR_CODE.getCode(), exception.getMessage(), null);  }}

验证一下

Fluent Mybatis中Update语法怎么用

Fluent Mybatis中Update语法怎么用

代码说明

可以看一下代码执行的具体sql,如下:

2021-11-23 13:41:20.277 DEBUG 20820 --- [nio-8090-exec-1] c.h.f.f.m.T.updateBy                     : ==>  Preparing: UPDATE `test_fluent_mybatis` SET `name` = ?, `age` = ? WHERE `id` = ?2021-11-23 13:41:20.464 DEBUG 20820 --- [nio-8090-exec-1] c.h.f.f.m.T.updateBy                     : ==> Parameters: 何九(String), null, 2(Integer)2021-11-23 13:41:20.470 DEBUG 20820 --- [nio-8090-exec-1] c.h.f.f.m.T.updateBy                     : <==    Updates: 1

UpdateByEntity根据表实体更新数据

fm支持使用表实体进行数据更新,但是有一些限制,具体看我后面的代码说明。

接口层代码添加

Integer updateByEntity(TestFluentMybatisEntity req);

实现类代码添加

@Overridepublic Integer updateByEntity(TestFluentMybatisEntity req) {  return testFluentMybatisMapper.updateBy(      new TestFluentMybatisUpdate()          .set          .byEntity(req, Ref.Field.TestFluentMybatis.name, Ref.Field.TestFluentMybatis.age)          .end()          .where          .id()          .eq(2)          .end());}

控制层代码添加

@Autowired private IUpdateService updateService; @ApiOperation(value = "根据实体更新语法", notes = "根据实体更新语法")@RequestMapping(value = "/updateByEntity", method = RequestMethod.POST)@ResponseBodypublic Result<Integer> updateByEntity(@RequestBody TestFluentMybatisEntity req) {  try {    return Result.ok(updateService.updateByEntity(req));  } catch (Exception exception) {    return Result.error(ErrorCode.BASE_ERROR_CODE.getCode(), exception.getMessage(), null);  }}

验证一下

Fluent Mybatis中Update语法怎么用

Fluent Mybatis中Update语法怎么用

代码说明

先看看sql的执行语句,如下图:

2021-11-23 13:56:16.572 DEBUG 20820 --- [nio-8090-exec-4] c.h.f.f.m.T.updateBy                     : ==>  Preparing: UPDATE `test_fluent_mybatis` SET `name` = ?, `age` = ? WHERE `id` = ?2021-11-23 13:56:16.573 DEBUG 20820 --- [nio-8090-exec-4] c.h.f.f.m.T.updateBy                     : ==> Parameters: 李四(String), 29(Integer), 2(Integer)2021-11-23 13:56:16.580 DEBUG 20820 --- [nio-8090-exec-4] c.h.f.f.m.T.updateBy                     : <==    Updates: 1

这里需要注意,在使用byEntity方法的时候,不会使用entity中的id作为判断的。官方原话为:未指定字段列表时, 更新除主键外非null字段。

byEntity方法支持传递字段参数,很好理解,只更新传递的字段值,不论是否为null。官方原话为:指定字段时,更新指定的字段(包括null字段), 但指定主键无效。

我在方法中选定了name、age两个字段,所以只更新这两项。

UpdateByExclude根据表实体排除更新数据

fm对排除字段情有独钟,简单理解一下,就是在设置字段的时候,byEntity是只选定选择的字段,byExclude是只排除选择的字段。

接口层代码添加

Integer updateByExclude(TestFluentMybatisEntity req);

实现类代码添加

@Overridepublic Integer updateByExclude(TestFluentMybatisEntity req) {  return testFluentMybatisMapper.updateBy(      new TestFluentMybatisUpdate()          .set          .byExclude(req, TestFluentMybatisEntity::getAge, TestFluentMybatisEntity::getDelFlag)          .end()          .where          .id()          .eq(2)          .end());}

控制层代码添加

@Autowired private IUpdateService updateService; @ApiOperation(value = "根据排除项更新语法", notes = "根据排除项更新语法")@RequestMapping(value = "/updateByExclude", method = RequestMethod.POST)@ResponseBodypublic Result<Integer> updateByExclude(@RequestBody TestFluentMybatisEntity req) {  try {    return Result.ok(updateService.updateByExclude(req));  } catch (Exception exception) {    return Result.error(ErrorCode.BASE_ERROR_CODE.getCode(), exception.getMessage(), null);  }}

验证一下

Fluent Mybatis中Update语法怎么用

Fluent Mybatis中Update语法怎么用

代码说明

先看看sql的执行语句,如下图:

2021-11-23 15:21:42.262 DEBUG 20820 --- [nio-8090-exec-6] c.h.f.f.m.T.updateBy                     : ==>  Preparing: UPDATE `test_fluent_mybatis` SET `name` = ?, `create_time` = ? WHERE `id` = ?2021-11-23 15:21:42.266 DEBUG 20820 --- [nio-8090-exec-6] c.h.f.f.m.T.updateBy                     : ==> Parameters: 李四(String), null, 2(Integer)2021-11-23 15:21:42.271 DEBUG 20820 --- [nio-8090-exec-6] c.h.f.f.m.T.updateBy                     : <==    Updates: 1

这里需要注意,实体中没有给create_time设值,所以会把其设置为null,官方原话为:未指定字段列表时, 更新除主键外字段(包括null字段)

而我指定了字段age和del_flag,但是并没有作用,这就是byExclude的作用,官方原话为:排除指定字段。

applyFunc

可以在更新语法中,增加对字段的函数操作,使用applyFunc即可,这个方法还是很好用的,简化代码。

接口层代码添加

Integer updateByApplyFunc();

实现类代码添加

@Overridepublic Integer updateByApplyFunc() {  return testFluentMybatisMapper.updateBy(      new TestFluentMybatisUpdate()          .set          .name()          .applyFunc("concat(name, ?)", "_男")          .set          .age()          .applyFunc("age+5")          .end()          .where          .id()          .eq(2)          .end());}

控制层代码添加

@Autowired private IUpdateService updateService; @ApiOperation(value = "使用applyFunc更新语法", notes = "使用applyFunc更新语法")@RequestMapping(value = "/updateByApplyFunc", method = RequestMethod.GET)@ResponseBodypublic Result<Integer> updateByApplyFunc() {  try {    return Result.ok(updateService.updateByApplyFunc());  } catch (Exception exception) {    return Result.error(ErrorCode.BASE_ERROR_CODE.getCode(), exception.getMessage(), null);  }}

验证一下

Fluent Mybatis中Update语法怎么用

Fluent Mybatis中Update语法怎么用

代码说明

先看看sql的执行语句,如下图:

2021-11-23 15:31:09.772 DEBUG 20820 --- [nio-8090-exec-8] c.h.f.f.m.T.updateBy                     : ==>  Preparing: UPDATE `test_fluent_mybatis` SET `name` = concat(name, ?), `age` = age+5 WHERE `id` = ?2021-11-23 15:31:09.782 DEBUG 20820 --- [nio-8090-exec-8] c.h.f.f.m.T.updateBy                     : ==> Parameters: _男(String), 2(Integer)2021-11-23 15:31:09.787 DEBUG 20820 --- [nio-8090-exec-8] c.h.f.f.m.T.updateBy                     : <==    Updates: 1

sql可以看出,将那么字段拼接了后缀"_男",同时年龄增加5岁。

看完了这篇文章,相信你对“Fluent Mybatis中Update语法怎么用”有了一定的了解,如果想了解更多相关知识,欢迎关注编程网行业资讯频道,感谢各位的阅读!

阅读原文内容投诉

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

软考中级精品资料免费领

  • 历年真题答案解析
  • 备考技巧名师总结
  • 高频考点精准押题
  • 2024年上半年信息系统项目管理师第二批次真题及答案解析(完整版)

    难度     813人已做
    查看
  • 【考后总结】2024年5月26日信息系统项目管理师第2批次考情分析

    难度     354人已做
    查看
  • 【考后总结】2024年5月25日信息系统项目管理师第1批次考情分析

    难度     318人已做
    查看
  • 2024年上半年软考高项第一、二批次真题考点汇总(完整版)

    难度     435人已做
    查看
  • 2024年上半年系统架构设计师考试综合知识真题

    难度     224人已做
    查看

相关文章

发现更多好内容

猜你喜欢

AI推送时光机
位置:首页-资讯-后端开发
咦!没有更多了?去看看其它编程学习网 内容吧
首页课程
资料下载
问答资讯