MyBatisPlus之DQL编程控制


🐌个人主页: 🐌 叶落闲庭

💨我的专栏:💨
c语言
数据结构
javaEE
操作系统

石可破也,而不可夺坚;丹可磨也,而不可夺赤。


MyBatisPlus之DQL编程控制

  • [一、 条件查询方式(三种格式)](#一、 条件查询方式(三种格式))
  • [二、 条件查询 -- -- null值处理](#二、 条件查询 -- -- null值处理)
    • [2.1 if语句控制追加](#2.1 if语句控制追加)
    • [2.2 条件参数控制](#2.2 条件参数控制)
    • [2.3 条件参数控制(链式编程)](#2.3 条件参数控制(链式编程))
  • 三、查询投影
    • [3.1 查询结果包含模型类中部分属性](#3.1 查询结果包含模型类中部分属性)
    • [3.2 查询结果包含模型类中未定义的属性](#3.2 查询结果包含模型类中未定义的属性)

一、 条件查询方式(三种格式)

  • MyBatisPlus将书写复杂的SQL查询条件进行了封装,使用编程的形式完成查询条件的组合
  • 格式一:常规格式
java 复制代码
		//方式一:按条件查询
		QueryWrapper qw = new QueryWrapper();
		//小于3
		qw.lt("id",3);
		List userList = userDao.selectList(qw);
		System.out.println(userList);
  • 格式二:链式编程查询
java 复制代码
		QueryWrapper qw = new QueryWrapper();
		//小于3大于1
		qw.lt("id",3).gt("id",1);
		List userList = userDao.selectList(qw);
		System.out.println(userList);
  • 格式三:lambda格式(推荐)
java 复制代码
		//方式三:lambda格式按条件查询
		LambdaQueryWrapper<User> lwq = new LambdaQueryWrapper<>();
		//id为1到3之间
		lwq.lt(User::getId,3);
		lwq.gt(User::getId,1);
		//id为小于2或者大于3
		//链式查询
		lwq.lt(User::getId,2).or().gt(User::getId,3);
		List userList = userDao.selectList(lwq);
		System.out.println(userList);
  • 并且:
java 复制代码
qw.lt("id",3).gt("id",1);
  • 或者:
java 复制代码
lwq.lt(User::getId,2).or().gt(User::getId,3);

二、 条件查询 -- -- null值处理

2.1 if语句控制追加

java 复制代码
		UserQuery uq = new UserQuery();
		uq.setId(1);
		uq.setId2(3);
		//null判定
		LambdaQueryWrapper<User> lqw = new LambdaQueryWrapper<>();
		if(null != uq.getId()) {
			lqw.lt(User::getId,uq.getId2());
		}
		if(null != uq.getId2()) {
			lqw.gt(User::getId,uq.getId());
		}
		List<User> userList = userDao.selectList(lqw);
		System.out.println(userList);

2.2 条件参数控制

java 复制代码
		//先判定第一个参数是否为true,如果为true,连接当前条件
		UserQuery uq = new UserQuery();
		uq.setId(1);
		uq.setId2(3);
		//null判定
		LambdaQueryWrapper<User> lqw = new LambdaQueryWrapper<>();
		lqw.gt(null!=uq.getId2(), User::getId, uq.getId())
		lqw.lt(null!= uq.getId(),User::getId,uq.getId2());
		List<User> userList = userDao.selectList(lqw);
		System.out.println(userList);

2.3 条件参数控制(链式编程)

java 复制代码
		//先判定第一个参数是否为true,如果为true,连接当前条件
		UserQuery uq = new UserQuery();
		uq.setId(1);
		uq.setId2(3);
		//null判定
		LambdaQueryWrapper<User> lqw = new LambdaQueryWrapper<>();
		lqw.gt(null!=uq.getId2(), User::getId, uq.getId())
					.lt(null!= uq.getId(),User::getId,uq.getId2());
		List<User> userList = userDao.selectList(lqw);
		System.out.println(userList);

三、查询投影

3.1 查询结果包含模型类中部分属性

java 复制代码
		LambdaQueryWrapper<User> lqw = new LambdaQueryWrapper<>();
		lqw.select(User::getId,User::getAddr);
		List<User> userList = userDao.selectList(lqw);
		System.out.println(userList);

3.2 查询结果包含模型类中未定义的属性

java 复制代码
		QueryWrapper<User> qw = new QueryWrapper<>();
		qw.select("count(*) as count");
		qw.groupBy("gender");
		List<Map<String, Object>> userList = userDao.selectMaps(qw);
		System.out.println(userList);
相关推荐
香蕉可乐荷包蛋34 分钟前
Python面试问题
开发语言·python·面试
ErizJ44 分钟前
Golang|分布式索引架构
开发语言·分布式·后端·架构·golang
.生产的驴1 小时前
SpringBoot 接口国际化i18n 多语言返回 中英文切换 全球化 语言切换
java·开发语言·spring boot·后端·前端框架
界面开发小八哥1 小时前
智能Python开发工具PyCharm v2025.1——AI层级功能重磅升级
ide·人工智能·python·pycharm·开发工具
八股文领域大手子1 小时前
深入浅出限流算法(三):追求极致精确的滑动日志
开发语言·数据结构·算法·leetcode·mybatis·哈希算法
啊阿狸不会拉杆1 小时前
人工智能数学基础(一):人工智能与数学
人工智能·python·算法
蹦蹦跳跳真可爱5891 小时前
Python----卷积神经网络(卷积为什么能识别图像)
人工智能·python·深度学习·神经网络·计算机视觉·cnn
geovindu1 小时前
PyCharm 2023升级2024 版本
ide·python·pycharm
几度泥的菜花2 小时前
优雅实现网页弹窗提示功能:JavaScript与CSS完美结合
开发语言·javascript·css
weixin_307779132 小时前
AWS Glue ETL设计与调度最佳实践
开发语言·数据仓库·云计算·etl·aws