常用配置
#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
其中前面每个参数的注解必须要写
javavoid 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>