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>
相关推荐
liliangcsdn1 分钟前
python如何写数据到excel示例
开发语言·python·excel
骑士雄师1 小时前
使用 IntelliJ IDEA 结合 DBeaver 连接 MySQL 数据库并实现数据增删查改的详细步骤:
数据库·mysql·intellij-idea
workflower3 小时前
单元测试-例子
java·开发语言·算法·django·个人开发·结对编程
YuanlongWang3 小时前
C# 基础——装箱和拆箱
java·开发语言·c#
b78gb3 小时前
电商秒杀系统设计 Java+MySQL实现高并发库存管理与订单处理
java·开发语言·mysql
wb043072014 小时前
性能优化实战:基于方法执行监控与AI调用链分析
java·人工智能·spring boot·语言模型·性能优化
LXS_3575 小时前
Day 05 C++ 入门 之 指针
开发语言·c++·笔记·学习方法·改行学it
天若有情6736 小时前
Java Swing 实战:从零打造经典黄金矿工游戏
java·后端·游戏·黄金矿工·swin
etsuyou6 小时前
js前端this指向规则
开发语言·前端·javascript
lichong9516 小时前
Android studio 修改包名
android·java·前端·ide·android studio·大前端·大前端++