MybatisPlus—自定义SQL

这篇具有很好参考价值的文章主要介绍了MybatisPlus—自定义SQL。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

目录

1. 自定义SQL介绍

2. 自定义SQL使用步骤 

3. 自定义SQL实例

4.总结


1. 自定义SQL介绍

        介绍:自定义SQL并不是由我们来编写全部SQL语句,而是通过利用MyBatisPlus的Wrapper来构建复杂的Where条件,然后自己定义SQL语句中剩下的部分。


        使用需求:如果我们想要对数据库某字段进行直接赋值,那么可以在Mapper层或者.xml层编写对应的SQL语句。如果我们要对数据库某字段进行特殊赋值或者动态赋值,又或者其他复杂的操作,如:更新字段balance=balance+20,我们不得不在业务层进行编写,而这样会导致代码编写不符合规范(SQL语句需要在Mapper层中编写),但直接编写SQL语句又十分冗长麻烦。因此我们可以使用自定义SQL的功能,将where条件交给MP编写,而剩余的Update、Select等语句由我们自定义编写(如下图所示)。
mybatisplus自定义sql,MybatisPlus,JavaWeb,学习笔记,sql,java,数据库


2. 自定义SQL使用步骤 

        自定义SQL方法在业务层定义where条件和需要使用的参数,并将where条件与参数传入自定义Mapper方法中,最后在Mapper方法或者xml文件中自定义编写剩余的SQL语句。 

mybatisplus自定义sql,MybatisPlus,JavaWeb,学习笔记,sql,java,数据库 


3. 自定义SQL实例

通过自定义SQL实现如下SQL语句:

update tb_user set balance = balance - 200 WHERE (id IN (1,2,4))
 /*Service层*/
    @Test
    void testCustomSqlUpdate() {
        //1. 设置更新条件
        List<Long> ids = List.of(1L, 2L, 4L);
        int amount = 200;
        //2. 定义where条件
        LambdaQueryWrapper wrapper = new LambdaQueryWrapper<User>().in(User::getId, ids);
        //3. 调用自定义SQL方法
        userMapper.updateBalanceByIds(wrapper, amount);
    }

/*Mapper层*/
    @Mapper
    public interface UserMapper extends BaseMapper<User> {
    //如果忘记"ew"可以用WRAPPER的常量代替:@Param(Constants.WRAPPER) 
    void updateBalanceByIds(@Param("ew") LambdaQueryWrapper wrapper, @Param("amount") int amount);
    }
<!-- xml文件 -->
    <update id="updateBalanceByIds">
        update tb_user set balance = balance - #{amount} ${ew.customSqlSegment}
    </update>

4.总结

        总结:自定义SQL方法在业务层定义where条件和需要使用的参数,并将where条件与参数传入自定义Mapper方法中,最后在Mapper方法或者xml文件中自定义编写剩余的SQL语句。

        使用场景:当遇到SQL语句中,除where条件之外的语句很难用MP编写的情况下,可以使用自定义SQL。文章来源地址https://www.toymoban.com/news/detail-859003.html

到了这里,关于MybatisPlus—自定义SQL的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • Mybatisplus 传参参数为自定义sql, 使用条件构造器作为参数

    1 pom依赖 2 mapper 接口文件 3 mapper 的xml配置文件 4 查询 5 测试,生成的两个sql语句如下 注意 :不同的版本,可能会有部分区别,总之注意下版本

    2024年02月22日
    浏览(41)
  • MyBatisPlus学习笔记一

            MyBatisPlus(简称MP)是一个MyBatis的增强工具,在MyBatisMyBatisMyBatis的的基础上只做增强不做改变,为简化开发,提高效率而生。 官网:MyBatis-Plus mybatisplus通过扫描实体类,并基于反射获取实体类信息作为数据库表结构。 约定大于配置。 类名驼峰转下划线作为表明

    2024年01月25日
    浏览(24)
  • MyBatisPlus学习笔记二

     接上:MyBatisPlus学习笔记一: MyBatisPlus学习笔记一-CSDN博客  MyBatisPlus支持各种复杂的where条件,可以满足日常开发的所有需求。 查询 lambda查询 更新         我们可以利用MyBatisPlus的Wrapper来构建复杂的Where条件,然后自己定义SQL语句中剩下的部分。  3.4、实例-serviceImpl

    2024年01月16日
    浏览(23)
  • MyBatisPlus学习笔记四-扩展功能

       先查询,再分组    

    2024年01月19日
    浏览(28)
  • MyBatisPlus学习笔记五-插件功能

    MyBatisPlus 提供的内置拦截器有下面这些 需求: 在 PageQuery 中定义方法,将 PageQuery 对象转为 MyBatisPlus 中的 Page对象 在 PageDTO 中定义方法,将 MyBatisPlus 中的 Page 结果转为 PageDTO 结果

    2024年01月20日
    浏览(29)
  • Doris学习笔记-Java自定义UDAF

    项目最近需要做一些数据统计方面的东西,发现数据字段都是很长一串数字的字符串,Doris自带的函数无法对其进行相应的运算操作,需要扩展实现相关的操作运算。 主要参考官方的文档资料完成相关的自定义扩展。需要注意的是在使用Java代码编写UDAF时,有一些必须实现的

    2024年01月16日
    浏览(23)
  • Java企业级开发学习笔记(4.4)Spring Boot加载自定义配置文件

    创建 Spring Boot 项目 单击【创建】按钮 在 resources 里创建 myconfig.properties 文件 设置文件编码 设置学生的四个属性值 在 cn.kox.boot 包里创建config子包,在子包里创建 StudentConfig 打开自带的测试类 ConfigDemo01ApplicationTests 注入学生配置实体,创建 testStudentConfig() 测试方法,在里面输

    2024年02月08日
    浏览(37)
  • javaweb学习笔记——Tomcat&Servlet

    web相关概念回顾 web服务器软件:Tomcat Servlet入门学习 1、软件架构 C/S:客户端/服务器端 B/S:浏览器/服务器端 2、资源分类 静态资源:所有用户访问后,得到的结果都是一样的,称为静态资源,静态资源可以直接被浏览器解析;如html,css,JavaScript 动态资源:每个用户访问相

    2024年02月07日
    浏览(34)
  • Javaweb基础-前端工程化学习笔记

    变量与模版字符串 let 和var的差别: const和var的差异 1、新增const和let类似,只是const定义的变量不能修改 2、并不是变量的值不得改动,而是变量指向的那个内存地址所保存的数据不得改动。 模板字符串(template string)是增强版的字符串,用反引号(`)标识 1、字符串中可以

    2024年02月20日
    浏览(40)
  • Java框架学习(二)SSM体系:Spring、SpringMVC、MybatisPlus

    在原始的分层架构实现中,负责响应请求的Controller层依赖于业务逻辑处理的Service层,而业务逻辑处理的service层又依赖与数据访问Dao层。上下层间相互依赖耦合,耦合的缺陷在于牵一发而动全身,不利于后期维护拓展。 为了分层解耦,Spring采用IoC控制反转和DI依赖注入,来解

    2024年02月11日
    浏览(36)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包