iis服务器助手广告广告
返回顶部
首页 > 资讯 > 精选 >Fluent Mybatis中Update语法怎么用
  • 754
分享到

Fluent Mybatis中Update语法怎么用

2023-06-21 20:06:48 754人浏览 八月长安
摘要

小编给大家分享一下Fluent mybatis中Update语法怎么用,希望大家阅读完这篇文章之后都有所收获,下面让我们一起去探讨吧!数据准备还是用之前在数据库存的数据,数据如下:Update语法简单的写法fm的update简单写

小编给大家分享一下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语法怎么用”有了一定的了解,如果想了解更多相关知识,欢迎关注编程网精选频道,感谢各位的阅读!

    --结束END--

    本文标题: Fluent Mybatis中Update语法怎么用

    本文链接: https://www.lsjlt.com/news/300410.html(转载时请注明来源链接)

    有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

    本篇文章演示代码以及资料文档资料下载

    下载Word文档到电脑,方便收藏和打印~

    下载Word文档
    猜你喜欢
    • Fluent Mybatis中Update语法怎么用
      小编给大家分享一下Fluent Mybatis中Update语法怎么用,希望大家阅读完这篇文章之后都有所收获,下面让我们一起去探讨吧!数据准备还是用之前在数据库存的数据,数据如下:Update语法简单的写法fm的update简单写...
      99+
      2023-06-21
    • springboot 中怎么整合fluent mybatis
      这篇文章给大家介绍springboot 中怎么整合fluent mybatis,内容非常详细,感兴趣的小伙伴们可以参考借鉴,希望对大家能有所帮助。导入pom依赖<!--     &nb...
      99+
      2023-06-20
    • Fluent Mybatis有什么用
      这篇文章主要介绍Fluent Mybatis有什么用,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!一、啥是Fluent-Mybatis与Mybatis-Plus类似,是对Mybaits进一步的封装,使之语法简洁明了,...
      99+
      2023-06-20
    • FluentMybatis怎么实现mybatis动态sql拼装和fluent api语法
      这篇文章主要讲解了“FluentMybatis怎么实现mybatis动态sql拼装和fluent api语法”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“FluentMybatis怎么实现m...
      99+
      2023-06-20
    • mybatis中update语句执行无效怎么解决
      这篇文章主要讲解了“mybatis中update语句执行无效怎么解决”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“mybatis中update语句执行无效怎么解决”吧!项目里myb...
      99+
      2023-06-21
    • Fluent MyBatis怎么实现动态SQL
      这篇文章主要讲解了“Fluent MyBatis怎么实现动态SQL”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“Fluent MyBatis怎么实现动态SQL”吧!目录数据准备代码生成在 W...
      99+
      2023-06-20
    • FluentMybatis实现mybatis动态sql拼装和fluent api语法
      目录开始第一个例子: Hello World新建演示用的数据库结构创建数据库表对应的Entity类运行测试来见证Fluent Mybatis的神奇配置spring bean定义使用J...
      99+
      2024-04-02
    • update语法是什么及怎么使用
      UPDATE语法用于修改表中的数据。它的基本语法如下:```UPDATE table_nameSET column1 = value...
      99+
      2023-06-13
      update语法
    • MySql update语句用法
      用法 你可以同时更新一个或多个字段。你可以在 WHERE 子句中指定任何条件。你可以在一个单独表中同时更新数据。 student idnameage1赵152钱163孙184赵145钱176孙19 将name='赵'的学...
      99+
      2023-09-02
      sql mysql 数据库 大数据 后端
    • Postgres中UPDATE更新语句怎么用
      这篇文章主要介绍Postgres中UPDATE更新语句怎么用,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!PG中UPDATE源码分析本文主要描述SQL中UPDATE语句的源码分析,代码为PG13.3版本。整体...
      99+
      2023-06-29
    • SqlServer中怎么批量update语句
      这期内容当中小编将会给大家带来有关SqlServer中怎么批量update语句,文章内容丰富且以专业的角度为大家分析和叙述,阅读完这篇文章希望大家可以有所收获。sqlserver as 语法举例1...
      99+
      2024-04-02
    • MySQL update语句的用法是什么
      MySQL的UPDATE语句用于修改表中现有记录的值,可以根据指定的条件更新指定的列。 UPDATE语句的基本语法如下: UPDAT...
      99+
      2024-02-29
      MySQL
    • sql中update用法
      非常抱歉,由于您没有提供文章标题,我无法为您生成一篇高质量的文章。请您提供文章标题,我将尽快为您生成一篇优质的文章。...
      99+
      2024-05-15
    • SQL的UPDATE语句怎么使用
      UPDATE语句用于修改数据库表中的数据记录。它的基本语法如下:```UPDATE 表名SET 列名1 = 值1, 列名2 = 值2...
      99+
      2023-08-09
      SQL UPDATE
    • mysql中update的用法
      mysql中update的用法:使用语法“update 表名称 set 列名称=新值 where 更新条件;”,update语句主要是用来修改表中的数据,从而更新表中已存在的数据记录。在表 students 中的实例:将 id 为...
      99+
      2024-04-02
    • sql中update的用法
      非常抱歉,由于您没有提供文章标题,我无法为您生成一篇高质量的文章。请您提供文章标题,我将尽快为您生成一篇优质的文章。...
      99+
      2024-05-15
    • mybatis中insert语句的用法是什么
      在MyBatis中,使用insert语句来向数据库中插入数据。insert语句的用法如下: 在Mapper XML文件中编写ins...
      99+
      2024-03-11
      mybatis
    • MySQL数据库update语句怎么用
      小编给大家分享一下MySQL数据库update语句怎么用,希望大家阅读完这篇文章之后都有所收获,下面让我们一起去探讨吧!1、第一种:使用b表数据更新a表update Player&nbs...
      99+
      2024-04-02
    • python中update怎么使用
      在Python中,`update()`方法是用于将一个字典的键值对添加到另一个字典中。下面是`update()`方法的语法和示例:语...
      99+
      2023-10-12
      python
    • unity脚本中的update()方法怎么使用
      在Unity脚本中,可以使用Update()方法来处理每一帧的逻辑。Update()方法是一个默认的Unity生命周期函数,它会在每...
      99+
      2023-09-29
      unity
    软考高级职称资格查询
    编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
    • 官方手机版

    • 微信公众号

    • 商务合作