mybatis-plus高级操作

lambda条件构造器 使用

  1. /**
  2. * lambda 条件构造器
  3. * 生成的sql语句 SELECT id,name,age,email,manager_id,create_time FROM user WHERE name LIKE ? AND age < ?
  4. */
  5. @Test
  6. public void selectLambda() {
  7. //创建lambda 条件构造器 的三种方法
  8. // LambdaQueryWrapper<User> lambda2 = new LambdaQueryWrapper<>();
  9. // LambdaQueryWrapper<User> lambda = new QueryWrapper<User>().lambda();
  10. LambdaQueryWrapper<User> lambda3 = Wrappers.<User>lambdaQuery();
  11. lambda3.like(User::getName, "雨").lt(User::getAge, 40);
  12. List<User> users = userMapper.selectList(lambda3);
  13. users.forEach(System.out::println);
  14. }
  15. /**
  16. * 名字为王姓并且(年龄小于40并且邮箱不为空)
  17. * name like '王%' and (age <40 or email in not null)
  18. * 生成的sql语句 SELECT id,name,age,email,manager_id,create_time FROM user WHERE name LIKE ? AND age < ?
  19. */
  20. @Test
  21. public void selectLambda2() {
  22. LambdaQueryWrapper<User> lambda3 = Wrappers.<User>lambdaQuery();
  23. lambda3.likeRight(User::getName, "王").and(qw -> qw.lt(User::getAge, 40).or().isNotNull(User::getEmail));
  24. List<User> users = userMapper.selectList(lambda3);
  25. users.forEach(System.out::println);
  26. }
  27. /**
  28. * 自定义sql 使用
  29. * Dao层 代码:
  30. *
  31. * @Select("select * from ${ew.customSqlSegment}")
  32. * List<User> selectAll(@Param(Constants.WRAPPER)Wrapper<User> wrapper);
  33. */
  34. @Test
  35. public void selectLambda4my() {
  36. LambdaQueryWrapper<User> lambda3 = Wrappers.<User>lambdaQuery();
  37. lambda3.likeRight(User::getName, "王").and(qw -> qw.lt(User::getAge, 40).or().isNotNull(User::getEmail));
  38. List<User> users = userMapper.selectAll(lambda3);
  39. users.forEach(System.out::println);
  40. }


xml方式自定义sql 这里只是个单表演示
application.yml 添加

  1. mybatis-plus:
  2. mapper-locations:
  3. - com/mp/mapper/*

UserMapper 接口 添加方法

  1. List<User> selectAll(@Param(Constants.WRAPPER) Wrapper<User> wrapper);
  2. IPage<User> selectUserPage(Page<User> page,@Param(Constants.WRAPPER)Wrapper<User> wrapper);

UserMpper.xml

  1. <?xml version="1.0" encoding="UTF-8"?>
  2. <!DOCTYPE mapper
  3. PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN"
  4. "http://mybatis.org/dtd/mybatis-3-mapper.dtd">
  5. <mapper namespace="com.mp.dao.UserMapper">
  6. <select id="selectAll" resultType="com.mp.entity.User">
  7. select * from user ${ew.customSqlSegment}
  8. </select>
  9. <select id="selectUserPage" resultType="com.mp.entity.User">
  10. select * from user ${ew.customSqlSegment}
  11. </select>
  12. </mapper>
  1. /**
  2. * lambda 条件构造器第四种创建方式 MP 3.0.7 新增的方式
  3. * 生成的sql语句 SELECT id,name,age,email,manager_id,create_time FROM user WHERE name LIKE ? AND age >= ?
  4. * 这个例子可以看出 代码更简洁了
  5. * 生成的sql语句 SELECT id,name,age,email,manager_id,create_time FROM user WHERE name LIKE ? AND age >= ?
  6. */
  7. @Test
  8. public void selectLambda3() {
  9. List<User> users = new LambdaQueryChainWrapper<User>(userMapper)
  10. .like(User::getName, "雨").ge(User::getAge, 20).list();
  11. users.forEach(System.out::println);
  12. }

MP的分页操作

baseMapper接口提供两种分页方法来实现物理分页(注:导包时导MP的包)
第一个返回实体对象 允许null 第二个人返回map 对象多用于在指定放回字段时使用,避免为指定字段null值出现

  1. IPage<T> selectPage(IPage<T> page, @Param("ew") Wrapper<T> queryWrapper);
  2. IPage<Map<String, Object>> selectMapsPage(IPage<T> page, @Param("ew") Wrapper<T> queryWrapper);

使用MP的分页需要配置 类

  1. package com.mp.configuration;
  2. import com.baomidou.mybatisplus.extension.plugins.PaginationInterceptor;
  3. import org.springframework.context.annotation.Bean;
  4. import org.springframework.context.annotation.Configuration;
  5. @Configuration
  6. public class MybatisPlusConfig {
  7. @Bean
  8. public PaginationInterceptor paginationInterceptor() {
  9. return new PaginationInterceptor();
  10. }
  11. }
  12. /**
  13. * 分页MP 分页插件
  14. */
  15. @Test
  16. public void selectPage() {
  17. QueryWrapper<User> queryWrapper = new QueryWrapper<User>();
  18. queryWrapper.ge("age", 26);
  19. //后面参数false 表示不查询总记录数
  20. Page<User> userPage = new Page<>(1, 2, false);
  21. /* IPage<User> iPage = userMapper.selectPage(userPage, queryWrapper);
  22. System.out.println("总页数"+iPage.getPages());
  23. System.out.println("总记录数"+iPage.getTotal());
  24. List<User> records = iPage.getRecords();
  25. records.forEach(System.out::println);
  26. */
  27. IPage<Map<String, Object>> iPage = userMapper.selectMapsPage(userPage, queryWrapper);
  28. System.out.println("总页数" + iPage.getPages());
  29. System.out.println("总记录数" + iPage.getTotal());
  30. List<Map<String, Object>> records = iPage.getRecords();
  31. records.forEach(System.out::println);
  32. }

自定义分页
UserMapper接口添加 xml方式和注解方式sql是相同的 上面有示例
IPage selectUserPage(Page page,@Param(Constants.WRAPPER)Wrapper wrapper);

UserMpper.xml 添加

  1. /**
  2. * 自定义分页方法
  3. */
  4. @Test
  5. public void selectMyPage() {
  6. QueryWrapper<User> queryWrapper = new QueryWrapper<User>();
  7. queryWrapper.ge("age", 26);
  8. //后面参数false 表示不查询总记录数
  9. Page<User> page = new Page<>(1, 2);
  10. IPage<User> iPage = userMapper.selectUserPage(page, queryWrapper);
  11. System.out.println("总页数" + iPage.getPages());
  12. System.out.println("总记录数" + iPage.getTotal());
  13. List<User> records = iPage.getRecords();
  14. records.forEach(System.out::println);
  15. }