这些Mybatis-Plus的使用小技巧,你应该知道的
推荐学习
- 真香警告!Alibaba珍藏版mybatis手写文档 , 刷起来
- 重识SSM , “超高频面试点+源码解析+实战PDF” , 一次性干掉全拿走
文章插图
1、条件查询(QueryWrapper)如果说 , 我们需要查询的 SQL 语句如下:
SELECT * FROM user_info WHERE 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 可为 null5、分页查询(联表)当我们需要关联表格分页查询时 , 第3步已经满足不了我们的需求了 , 那么我们需要进行联表分页查询
假设我们需要的 SQL 语句如下:
SELECT a.*, b.`name` AS sex_text FROM user_info a LEFT JOIN user_sex b ON ( a.sex = b.id ) WHERE 1 = 1AND a.age > 20
那么我们需要进行如下操作:- 1、新建 UserInfoVO.java
import com.zyxx.entity.UserInfo;import lombok.Data;@Datapublic class UserInfoVO extends UserInfo {// 性别private String sexText;
- 2、UserInfoMapper.java 中
IPage list(Page page, @Param(Constants.WRAPPER) Wrapper queryWrapper);
- 3、UserInfoMapper.xml 中
SELECTa.*,b.`name` AS sex_textFROMuser_info aLEFT JOIN user_sex b ON ( a.sex = b.id )${ew.customSqlSegment}
- 4、UserInfoServiceImpl.java 中
// 条件查询LambdaQueryWrapper queryWrapper = new LambdaQueryWrapper<>();queryWrapper.eq(UserInfo::getAge, 20);// 分页对象Page queryPage = new Page<>(page, limit);// 分页查询IPage iPage = userInfoMapper.list(queryPage , queryWrapper);// 数据总数Long total = iPage.getTotal();// 用户数据List list = iPage.getRecords();
以上就是分页查询(联表)时的操作 , 这个应该是用的比较多的6、AND 和 ORqueryWrapper 默认是按照 and 来连接的 , 但是在我们业务需求中 , 肯定会用到 or 来写 SQL
- 1、初级假设我们需要的 SQL 语句如下:
SELECT a.* FROM user_info a WHERE 1 = 1AND a.id <> 1AND ( a.`name` = 'jack' OR a.phone = '13888888888' )
那么我们可以这样写:LambdaQueryWrapper queryWrapper = new LambdaQueryWrapper<>();// AND a.id <> 1 queryWrapper.ne(UserInfo::getId, "1");// AND ( a.`name` = 'jack' OR a.phone = '13888888888' )queryWrapper.and(i -> i.eq(UserInfo::getName, "jack").or().eq(UserInfo::getPhone, "13888888888"));// 查询结果List list = userInfoMapper.selectList(queryWrapper);
以上就完成了初级的 and 和 or 联用的情况- 2、复杂假设我们需要的 SQL 语句如下:
SELECT a.* FROM user_info a WHERE 1 = 1AND a.id <> 1AND ( (a.`name` = 'jack' AND a.category = 1) OR (a.phone = '13888888888' OR a.category = 2) )
那么我们可以这样写:LambdaQueryWrapper queryWrapper = new LambdaQueryWrapper<>();// AND a.id <> 1 queryWrapper.ne(UserInfo::getId, "1");// AND ( (a.`name` = 'jack' AND a.category = 1) OR (a.phone = '13888888888' OR a.category = 2) )queryWrapper.and(i -> (i.and(j -> j.eq(UserInfo::getName, "jack").eq(UserInfo::getCategory, 1))).or(j -> j.eq(UserInfo::getPhone, "13888888888").eq(UserInfo::getCategory, 2)));// 查询结果List list = userInfoMapper.selectList(queryWrapper);
以上就完成了复杂的 and 和 or 联用的情况那么以后遇见更复杂的 , 可以按此规则继续进行拼接 SQL
- 智能手机市场|华为再拿第一!27%的份额领跑全行业,苹果8%排在第四名!
- 会员|美容院使用会员管理软件给顾客更好的消费体验!
- 行业|现在行业内客服托管费用是怎么算的
- 人民币|天猫国际新增“服务大类”,知舟集团提醒入驻这些类目的要注意
- 国外|坐拥77件专利,打破国外的垄断,造出中国最先进的家电芯片
- 技术|做“视频”绿厂是专业的,这项技术获人民日报评论点赞
- 面临|“熟悉的陌生人”不该被边缘化
- 中国|浅谈5G移动通信技术的前世和今生
- 页面|如何简单、快速制作流程图?上班族的画图技巧get
- 桌面|日常使用的软件及网站分享 篇一:几个动态壁纸软件和静态壁纸网站:助你美化你的桌面