最近在用 Mybatis-Plus,嗯,真香!!!今天就来说说 Mybatis-Plus 的那些使用技巧
1、条件查询(QueryWrapper)
如果说,我们需要查询的 SQL 语句如下:
SELECT * FROM user_info WHERE 1=1 AND age = 20
那么对应的代码可以为:
QueryWrapper queryWrapper = new QueryWrapper<>();
queryWrapper.eq("age", 20);
List list = userInfoMapper.selectList(queryWrapper );
以上就是查询用户表,用户年龄大于20的用户信息
2、条件查询(QueryWrapper lambda)
QueryWrapper queryWrapper = new QueryWrapper<>();
queryWrapper.lambda().eq(UserInfo::getAge, 20);
List list = userInfoMapper.selectList(queryWrapper );
以上就是 QueryWrapper 的 lambda 表达式写法,这样能够避免写字段名写错,或者未转换驼峰写法导致 SQL 错误
3、条件查询(LambdaQueryWrapper)
LambdaQueryWrapper queryWrapper = new LambdaQueryWrapper<>();
queryWrapper.eq(UserInfo::getAge, 20);
List list = userInfoMapper.selectList(queryWrapper );
LambdaQueryWrapper 与 QueryWrapper 的 lambda 写法基本一致
4、分页查询
// 条件查询
LambdaQueryWrapper queryWrapper = new LambdaQueryWrapper<>();
queryWrapper.eq(UserInfo::getAge, 20);
// 分页对象
Page queryPage = new Page<>(page, limit);
// 分页查询
IPage iPage = userInfoMapper.selectPage(queryPage , queryWrapper);
// 数据总数
Long total = iPage.getTotal();
// 用户数据
List list = iPage.getRecords();
以上就是分页查询,如果无需条件查询,queryWrapper 可为 null
5、分页查询(联表)
当我们需要关联表格分页查询时,第3步已经满足不了我们的需求了,那么我们需要进行联表分页查询
假设我们需要的 SQL 语句如下:
SELECT
a.*,
b.`name` AS sex_text</