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

发布于:2024-12-06 ⋅ 阅读:(97) ⋅ 点赞:(0)

常用配置

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

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

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

     userMapper.selectList(wrapper) ;
    }
  @Test
    void testUpdate(){
        //要更新的数据
        User user = new User();
        user.setBalance(4000);
        //条件过滤
        UpdateWrapper<User> wrapper = new UpdateWrapper<User>().eq("username", "jack") ;
        //执行更新
        userMapper.update(user, wrapper) ;
    }
 @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来改善代码的硬编码情况
 

  @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

  @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
        其中前面每个参数的注解必须要写

void updateBalanceByIds(@Param(Constants.WRAPPER) 
    LambdaUpdateWrapper<User> wrapper,@Param("amount") int amount);

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

    <update id="updateBalanceByIds">
        update user set balance = balance - #{amount} ${ew.customSqlSegment}
    </update>

网站公告

今日签到

点亮在社区的每一天
去签到