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>
相关推荐
小光学长22 分钟前
基于vue框架的防疫科普网站0838x(程序+源码+数据库+调试部署+开发环境)带论文文档1万字以上,文末可获取,系统界面在最后面。
数据库
极限实验室27 分钟前
使用 Docker Compose 简化 INFINI Console 与 Easysearch 环境搭建
数据库·docker·devops
秋千码途30 分钟前
小架构step系列08:logback.xml的配置
xml·java·logback
飞翔的佩奇32 分钟前
Java项目:基于SSM框架实现的旅游协会管理系统【ssm+B/S架构+源码+数据库+毕业论文】
java·数据库·mysql·毕业设计·ssm·旅游·jsp
时来天地皆同力.1 小时前
Java面试基础:概念
java·开发语言·jvm
hackchen1 小时前
Go与JS无缝协作:Goja引擎实战之错误处理最佳实践
开发语言·javascript·golang
找不到、了1 小时前
Spring的Bean原型模式下的使用
java·spring·原型模式
阿华的代码王国2 小时前
【Android】搭配安卓环境及设备连接
android·java
YuTaoShao2 小时前
【LeetCode 热题 100】141. 环形链表——快慢指针
java·算法·leetcode·链表
铲子Zzz2 小时前
Java使用接口AES进行加密+微信小程序接收解密
java·开发语言·微信小程序