MyBatisPlus——DQL编程控制——条件查询
DQL编程控制
条件查询——设置查询条件
- 格式一:常规格式
//方式一:按条件查询
QueryWrapper qw = new QueryWrapper();
// 10岁到30岁之间的用户
qw.gt("age",10);
qw.lt("age",30);
List<User> users = userDao.selectList(qw);
System.out.println(users);
- 格式二:链式编程格式
//方式一:按条件查询
QueryWrapper qw = new QueryWrapper();
// 10岁到30岁之间的用户
qw.gt("age",10).lt("age",30);
List<User> users = userDao.selectList(qw);
System.out.println(users);
- 格式三:lambda格式(推荐)
//方式二:lambda格式按条件查询
QueryWrapper<User> qw = new QueryWrapper();
// 10岁到30岁之间的用户
qw.lambda().gt(User::getAge,10).lt(User::getAge,30);
List<User> users = userDao.selectList(qw);
System.out.println(users);
- 格式四:lambda格式(推荐)
// 方式三:lambda格式按条件查询
LambdaQueryWrapper<User> lqw = new LambdaQueryWrapper<>();
// 10岁到30岁之间的用户
//lqw.gt(User::getAge,10).lt(User::getAge,30);
// 小于10岁或者大于30岁的用户
lqw.gt(User::getAge,30).or().lt(User::getAge,10);
List<User> users = userDao.selectList(lqw);
System.out.println(users);
- 直接链式编程表示且关系
- 要表示或关系需要在中间加上
.or()
// 小于10岁或者大于30岁的用户
lqw.gt(User::getAge,30).or().lt(User::getAge,10);
条件查询——null值处理
- 条件参数控制
// 模拟页面传递过来的数据
UserQuery uq = new UserQuery();
//uq.setAge(10);
uq.setAge2(30);
// null值判定(尽量不用链式编程,过于长了)
LambdaQueryWrapper<User> lqw = new LambdaQueryWrapper();
lqw.gt(null != uq.getAge(),User::getAge,uq.getAge());
lqw.lt(null != uq.getAge2(), User::getAge,uq.getAge2());
List<User> users = userDao.selectList(lqw);
System.out.println(users);
查询投影
- 只查询一部分字段
// 查询投影——只查询部分字段
LambdaQueryWrapper<User> lqw = new LambdaQueryWrapper();
lqw.select(User::getId,User::getName);
List<User> users = userDao.selectList(lqw);
System.out.println(users);
- 若要完成模型类中
未定义的属性(聚合函数)或是分组查询,则不能使用lambda格式
// 查询count(*) 不能使用lambda格式
QueryWrapper<User> qw = new QueryWrapper();
qw.select("count(*) as count, tle");
qw.groupBy("tle");
List<Map<String, Object>> userList = userDao.selectMaps(qw);
System.out.println(userList);
查询条件
- 匹配(等于)
LambdaQueryWrapper<User> lqw = new LambdaQueryWrapper();
// 等于
lqw.eq(User::getName,"王麻子").eq(User::getTle,"10086");
User loginUser = userDao.selectOne(lqw);
System.out.println(loginUser);
- 范围查询(between)
// 范围查询 lt-小于 le-小于等于 gt-大于 ge-大于等于 eq-等于 ne-不等于 between-范围查询
LambdaQueryWrapper<User> lqw1 = new LambdaQueryWrapper();
// 10岁到30岁之间的用户
lqw1.between(User::getAge,10,30);
List<User> userList = userDao.selectList(lqw1);
System.out.println(userList);
- 模糊匹配(like-非全文检索版)
// 模糊匹配 like-模糊匹配 notLike-不模糊匹配
LambdaQueryWrapper<User> lqw2 = new LambdaQueryWrapper();
// 名字带有王的用户
//lqw2.like(User::getName,"王");
// likeRight—— 王%
lqw2.likeRight(User::getName,"王");
// likeLeft—— %王
lqw2.likeLeft(User::getName,"王");
List<User> userList2 = userDao.selectList(lqw2);
System.out.println(userList2);
字段映射与表名映射
- 问题一:表字段属性与编码属性设计不同步

- 问题二编码中添加了数据库中未定义的属性

- 问题三:采用默认查询(select * ...)开放了更多字段的查看权限

- 使用注解:@TableField
- 类型:属性注解
- 位置:模型类属性定义上方
- 作用设置当前属性对应的数据库表中的字段关系
- 范例



- 相关属性
- value(默认):设置数据库表字段名称
- exist:设置属性在数据库字段中是否存在,默认为true。此属性无法与value属性合并使用
- select:设置属性是否参与查询,此属性与select()映射配置不冲突
- 相关属性
- 问题四:表名与编码开发设计不同步

- 使用注解:
@TableName - 类型:类注解
- 位置:模型类定义上方
- 作用:设置当前类对应与数据库表关系
- 范例
- 使用注解:

- 相关属性
- value:设置数据库表名称
- 相关属性
MyBatisPlus——DQL编程控制——条件查询的更多相关文章
- Java开发学习(四十二)----MyBatisPlus查询语句之条件查询
一.条件查询的类 MyBatisPlus将书写复杂的SQL查询条件进行了封装,使用编程的形式完成查询条件的组合. 这个我们在前面都有见过,比如查询所有和分页查询的时候,都有看到过一个Wrapper类, ...
- 【mybatis-plus】条件查询
用mp也可以方便的实现稍复杂点的条件查询,当然了很复杂的就还是要xml编写sql了. 一.wapper介绍 先看下mp的条件构造抽象类的结构: Wrapper: 条件构造抽象类,最顶端父类 Abstr ...
- DQL基础查询和DQL条件查询
DQL:查询表中的记录 1.语法 select 字段列表 from 表名列表 where 条件列表 group by 分组字段 having 分组之后的条件 order by 排序 limit 分页限 ...
- MySQL(四)DQL语言——条件查询
摘要:条件查询:条件表达式,逻辑表达式,模糊查询,like,通配符,转义字符,escape关键字,between and,in,is null,is not null,安全等于. 条件查询语法: SE ...
- SQL语言学习-DQL条件查询
条件查询 1. where子句后跟条件 2. 运算符 * > .< .<= .>= .= .<> * BETWEEN...AND * IN( 集合) * LIKE: ...
- HBase高性能复杂条件查询引擎
转自:http://blog.csdn.net/bluishglc/article/details/31799255 mark 写在前面 本文2014年7月份发表于InfoQ,HBase的PMC成员T ...
- MyBatisPlus---DQL编程控制
MP将书写复杂的SQL查询条件进行了封装,使用编程的形式完成查询条件的组合. 一.条件查询 package com.itheima; import com.baomidou.mybatisplus.c ...
- mongodb_查询操作使用_条件查询、where子句等(转)
<?php /* mongodb_查询操作使用_条件查询.where子句等(转并学习) 1.find()/findOne() mongodb数据库的查询操作即使用find()或者findO ...
- SQL编程之高级查询(子查询)以及注意事项
SQL编程之高级查询(子查询)以及注意事项 1.什么是子查询? 当一个查询是另一个查询的条件时,称之为子查询.子查询可以使用几个简单命令构造功能强大的复合命令.子查询最常用于SELECT-SQL命 ...
- 动态多条件查询分页以及排序(一)--MVC与Entity Framework版url分页版
一.前言 多条件查询分页以及排序 每个系统里都会有这个的代码 做好这块 可以大大提高开发效率 所以博主分享下自己的6个版本的 多条件查询分页以及排序 二.目前状况 不论是ado.net 还是EF ...
随机推荐
- card 卡片 html
{% extends 'base.html' %} {% block content %} <div class="container"> <h1>客户信息 ...
- 解决“网页源代码编码形式为utf-8,但爬虫代码设置为decode('utf-8')仍出现汉字乱码”的问题
为了用爬虫获取百度首页的源代码,检查了百度的源代码,显示编码格式为utf-8 但这样写代码,却失败了-.. (这里提示:不要直接复制百度的URL,应该是http,不是https!!!) # 获取百度首 ...
- MySQL 跨服务器关联查询
如果您需要在 MySQL 中关联查询位于不同服务器的表(跨服务器关联查询),您可以考虑使用 MySQL 的联机查询(Federated MySQL).联机查询允许您在一个服务器上访问和查询另一个服务器 ...
- java开发环境安装IDEA+jdk1.8
一. 需要得安装包 (1)IDEA破解版.zip (2)jdk1.8.0_25.7z 获取方式(免费): (1) 登录-注册:http://resources.kittytiger.cn/ ...
- docker dockerfile基础指令
dockerfile是用来构建docker镜像文件!命令参数脚本 构建步骤 1.编写一个dockerfile文件 2.dockerbuild构建成为一个镜像 3.docker run运行镜像 4.do ...
- .NET 开源快捷的数据库文档查询和生成工具
前言 在实际项目开发中,需求变更和项目迭代是常态.要求我们能够迅速响应,对数据库结构进行相应的调整,如添加新表.更新现有表结构或增加字段等. 为了确保团队成员之间的信息同步,实时更新和维护数据库文档变 ...
- 【Windows】解决微软商店打不开的问题
参考贴吧的帖子: https://tieba.baidu.com/p/6028738660#123983609458l 1.打开"运行"输入 inetcpl.cpl (" ...
- 使用浪潮AI计算平台之分布式计算(Tensorflow框架下 PS/Worker模式下的异步计算)
虽然Tensorflow一直都是支持分布式计算的,但是由于只有一台电脑,一个GPU,所以别说分布式的tensorflow的使用了,就是单机多卡都是没有使用过的,由于后来可以有机会使用这个浪潮的AI计算 ...
- Ubuntu18.04下 修改conda环境和缓存默认路径
查看conda 的默认环境和缓存默认路径:conda info conda环境和缓存的默认路径(envs directories 和 package cache) envs directories ...
- DataOps 新趋势:联通数科如何利用 DolphinScheduler 实现数据一体化管理
引言 在DataOps(数据运营)的推动下,越来越多的企业开始关注数据研发和运营的一体化建设.DataOps通过自动化和流程优化,帮助企业实现数据的高效流转和管理. 当前,Apache Dolphin ...