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编程控制——条件查询的更多相关文章

  1. Java开发学习(四十二)----MyBatisPlus查询语句之条件查询

    一.条件查询的类 MyBatisPlus将书写复杂的SQL查询条件进行了封装,使用编程的形式完成查询条件的组合. 这个我们在前面都有见过,比如查询所有和分页查询的时候,都有看到过一个Wrapper类, ...

  2. 【mybatis-plus】条件查询

    用mp也可以方便的实现稍复杂点的条件查询,当然了很复杂的就还是要xml编写sql了. 一.wapper介绍 先看下mp的条件构造抽象类的结构: Wrapper: 条件构造抽象类,最顶端父类 Abstr ...

  3. DQL基础查询和DQL条件查询

    DQL:查询表中的记录 1.语法 select 字段列表 from 表名列表 where 条件列表 group by 分组字段 having 分组之后的条件 order by 排序 limit 分页限 ...

  4. MySQL(四)DQL语言——条件查询

    摘要:条件查询:条件表达式,逻辑表达式,模糊查询,like,通配符,转义字符,escape关键字,between and,in,is null,is not null,安全等于. 条件查询语法: SE ...

  5. SQL语言学习-DQL条件查询

    条件查询 1. where子句后跟条件 2. 运算符 * > .< .<= .>= .= .<> * BETWEEN...AND * IN( 集合) * LIKE: ...

  6. HBase高性能复杂条件查询引擎

    转自:http://blog.csdn.net/bluishglc/article/details/31799255 mark 写在前面 本文2014年7月份发表于InfoQ,HBase的PMC成员T ...

  7. MyBatisPlus---DQL编程控制

    MP将书写复杂的SQL查询条件进行了封装,使用编程的形式完成查询条件的组合. 一.条件查询 package com.itheima; import com.baomidou.mybatisplus.c ...

  8. mongodb_查询操作使用_条件查询、where子句等(转)

    <?php /*  mongodb_查询操作使用_条件查询.where子句等(转并学习)   1.find()/findOne() mongodb数据库的查询操作即使用find()或者findO ...

  9. SQL编程之高级查询(子查询)以及注意事项

    SQL编程之高级查询(子查询)以及注意事项   1.什么是子查询? 当一个查询是另一个查询的条件时,称之为子查询.子查询可以使用几个简单命令构造功能强大的复合命令.子查询最常用于SELECT-SQL命 ...

  10. 动态多条件查询分页以及排序(一)--MVC与Entity Framework版url分页版

    一.前言 多条件查询分页以及排序  每个系统里都会有这个的代码 做好这块 可以大大提高开发效率  所以博主分享下自己的6个版本的 多条件查询分页以及排序 二.目前状况 不论是ado.net 还是EF ...

随机推荐

  1. 背景色透明度兼容IE8的写法

    本文为Echoyya.所创,转载请带上原文链接,感谢 https://www.cnblogs.com/echoyya/p/14236242.html 通常的做法 目前大多数浏览器都支持 CSS3,只需 ...

  2. Python win11 安装lxml 失败

    如果你有一个项目执行了requirements后,一直提示lxml失败,解决步骤如下 1.尝试升级pip python.exe -m pip install --upgrade pip 2.尝试下载包 ...

  3. 题解:P10781 【MX-J1-T1】『FLA - III』Spectral

    本题的主要思路就是数学. 首先,让我们先来打一个表. \(i\) \(1\) \(2\) \(3\) \(4\) \(\dots\) \(T_{i}\) \(k\) \(1.5k\) \(1.5k\) ...

  4. Activity的创建

    Activity的创建: 1.layout内写入相关代码 此处为显示的页面 2.Java内创建相关类写入代码 3.在清单内写入 快捷方法:直接完成上面步骤 layout: match_parent// ...

  5. 【H5】16 表单 其五 表单验证

    在将数据提交到服务器之前,重要的是确保以正确的格式填写所有必需的表单控件.这称为客户端表单验证,可帮助确保所提交的数据符合各种表单控件中规定的要求.本文将引导您通过基本概念和客户端表单验证示例. 先决 ...

  6. 【Dos-BatchPrograming】03

    --1.AT 计划任务 Microsoft Windows [版本 10.0.19041.746] (c) 2020 Microsoft Corporation. 保留所有权利. C:\Users\A ...

  7. 使用AI技术(单张图片或文字)生产3D模型 —— Ai生成3D模型的时代来了

    地址: https://www.bilibili.com/video/BV1A2421P7pH/ 视频用到的工具voxcraft体验地址:https://voxcraft.ai/

  8. OneFlow框架0.9.1dev版本,成功安装并运行

    安装cuda和cudnn: (此步骤可以忽略,pip安装框架时会自动安装依赖的cuda和cudnn环境) conda install cudatoolkit==11.8.0 python3 -m pi ...

  9. docker 容器(container)使用ssh服务登录一段时间无操作后自动断开问题解决

    如题,ssh登录建立好的docker容器,无操作一段时间后,发现ssh自动断开: 解决方法: 修改配置文件 /ect/ssh/sshd_config 在文件最后添加下面内容: PermitRootLo ...

  10. Ubuntu18.04server 双网卡,开机自动设置路由并启动校园网网络认证程序(Ubuntu开机自动设置路由,开机自启动应用程序)

    本博主为高龄在校生,实验室服务器需要假期时候无人守候也能实现自动登录校园网从而实现网络连接,以使实验室同学在家也可以使用校园vpn连接服务器. 由于假期时候实验室没有人,而假期实验室可能会出现断电断网 ...