MybatisPlus的使用(MybatisPlus的配置,wrapper的使用和自定义sql)

常用配置

复制代码
#MybatisPlus
mybatis-plus:
  global-config:
        db-config:
          id-type: auto #设置主键自增长策略
  type-aliases-package: com.itheima.mp.domain.po #别名扫描包 用于在mapper.xml中不需要指定全类名而简写

Wrapper是一个包装器 其中封装了很多方法让我们能够做条件判断

java 复制代码
 @Test
    void testQuery(){
        QueryWrapper<User> wrapper = new QueryWrapper<User>()
                .select("id","username","info","balance")
                        .like("username", "o")
                                .ge("balance", 2000) ;

     userMapper.selectList(wrapper) ;
    }
java 复制代码
  @Test
    void testUpdate(){
        //要更新的数据
        User user = new User();
        user.setBalance(4000);
        //条件过滤
        UpdateWrapper<User> wrapper = new UpdateWrapper<User>().eq("username", "jack") ;
        //执行更新
        userMapper.update(user, wrapper) ;
    }
java 复制代码
 @Test
    void testUpdateWrapper(){
        UpdateWrapper<User> wrapper = new UpdateWrapper<User>()
                .setSql("balance = balance -200 ")
                        .in("id", List.of(1L,2L,4L)) ;

        userMapper.update(null,wrapper) ;
    }

推荐使用Lambda来改善代码的硬编码情况

java 复制代码
  @Test
    void testLamdomUpdateWrapper(){
        LambdaUpdateWrapper<User> wrapper = new LambdaUpdateWrapper<User>()
                .setSql("balance = balance - 200 " )
                .in(User::getId, List.of(1L,2L,3L))
                ;
        userMapper.update(null, wrapper) ;
    }

自定义sql

java 复制代码
  @Test
    void testCustomSqlUpdate(){
        List<Long> ids = List.of(1L, 2L, 3L);
        int amount = 200 ;
        LambdaUpdateWrapper<User> wrapper = new LambdaUpdateWrapper<User>();
        wrapper.in(User::getId, ids) ;
        userMapper.updateBalanceByIds(wrapper,amount) ;
    }

Mapper

其中前面每个参数的注解必须要写

java 复制代码
void updateBalanceByIds(@Param(Constants.WRAPPER) 
    LambdaUpdateWrapper<User> wrapper,@Param("amount") int amount);

Mapper.xml

${ew.customSqlSegment}为固定写法 用来拼接where语句

java 复制代码
    <update id="updateBalanceByIds">
        update user set balance = balance - #{amount} ${ew.customSqlSegment}
    </update>
相关推荐
Elastic 中国社区官方博客3 分钟前
Elasticsearch 中的文档级基于属性的访问控制 - ABAC
大数据·数据库·elasticsearch·搜索引擎·全文检索
泉城老铁3 分钟前
windows服务器mysql数据库备份脚本
java·后端·mysql
神奇的板烧6 分钟前
Java泛型不变性引发的类型转换问题及解决方案
java·c#
数据库学啊9 分钟前
国产时序数据库供应商排名
数据库·时序数据库
CoderYanger10 分钟前
动态规划算法-简单多状态dp问题:16.买卖股票的最佳时机含手续费
开发语言·算法·leetcode·动态规划·1024程序员节
计算机学姐18 分钟前
基于Python的校园美食推荐系统【2026最新】
开发语言·vue.js·后端·python·mysql·django·推荐算法
悦悦子a啊28 分钟前
[Java]实验--编写TCP客户端程序
java·tcp/ip·php
songtaiwu33 分钟前
golang开发日常注意
开发语言·数据库·golang
NineData36 分钟前
NineData社区版V4.7.0发布!新增MySQL至TiDB等6条数据复制对比链路,SQL窗口新增谷歌云6种数据源类型
数据库·dba