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>
相关推荐
geovindu4 分钟前
D3.js Org Chart
开发语言·javascript·ecmascript
疋瓞6 分钟前
excel实用问题:提取文字当中的数字进行运算
java·javascript·excel
苏-言29 分钟前
RabbitMQ深度探索:简单实现 MQ
java·rabbitmq·java-rabbitmq
张焚雪33 分钟前
关于图像锐化的一份介绍
开发语言·python·opencv·计算机视觉
CodeClimb43 分钟前
【华为OD-E卷 - 任务最优调度 100分(python、java、c++、js、c)】
java·javascript·c++·python·华为od
锐策1 小时前
『 C++ 』中理解回调类型在 C++ 中的使用方式。
开发语言·c++
苹果酱05671 小时前
人工智能基础知识速成 - 机器学习、深度学习算法原理及其实际应用案例
java·vue.js·spring boot·mysql·课程设计
望未来无悔1 小时前
系统学习算法:专题九 穷举vs暴搜vs深搜vs回溯vs剪枝
java·算法
美味小鱼1 小时前
Rust错误处理:从灭火器到核按钮的生存指南
开发语言·后端·rust
SomeB1oody1 小时前
【Rust自学】19.1. 摆脱安全性限制的unsafe Rust
开发语言·后端·rust