当前位置: 首页 > article >正文

MybatisPlus入门(七)MybatisPlus-DQL编程控制

        一、查询投影


查询投影:查出来的东西有多少字段,设置查询出来的结果长什么样,查出的字段控制;


查询投影适用于lamda格式,使用select 查询   lqw.select(User::getId,User::getName,User::getAge);

代码示例:

        LambdaQueryWrapper<User> lqw = new LambdaQueryWrapper<User>();
        lqw.select(User::getId,User::getName,User::getAge);
        QueryWrapper<User> lqw = new QueryWrapper<User>();
        lqw.select("id","name","age","tel");
        List<User> userList = userDao.selectList(lqw);
        System.out.println(userList);

普通查询查询投影,代码示例:
        

QueryWrapper<User> lqw = new QueryWrapper<User>();
lqw.select("id", "name", "age", "tel");
List<User> userList = userDao.selectList(lqw);
System.out.println(userList);

查询 count (*)使用List<Map<String, Object>> userList = userDao.selectMaps(lqw);

查询投影和分组代码示例:

QueryWrapper<User> lqw = new QueryWrapper<User>();
lqw.select("count(*) as count, tel");
lqw.groupBy("tel");
List<Map<String, Object>> userList = userDao.selectMaps(lqw);
System.out.println(userList);

查询结果包含模型类中部分属性,代码示例:

/*LambdaQueryWrapper<User> lqw = new LambdaQueryWrapper<User>();
lqw.select(User::getId, User::getName, User::getAge);*/
//或者
QueryWrapper<User> lqw = new QueryWrapper<User>();
lqw.select("id", "name", "age", "tel");
List<User> userList = userDao.selectList(lqw);
System.out.println(userList);

查询结果包含模型类中未定义的属性,代码示例:

QueryWrapper<User> lqw = new QueryWrapper<User>();
lqw.select("count(*) as count, tel");
lqw.groupBy("tel");
List<Map<String, Object>> userList = userDao.selectMaps(lqw);
System.out.println(userList);

二、查询条件设置

查询条件如下图:

用户登录(eq匹配),代码示例:

LambdaQueryWrapper<User> lqw = new LambdaQueryWrapper<User>();
//等同于=
lqw.eq(User::getName, "Jerry").eq(User::getPassword, "jerry");
User loginUser = userDao.selectOne(lqw);
System.out.println(loginUser);

购物设定价格区间、户籍设定年龄区间(le ge匹配 或 between匹配)

代码示例:

LambdaQueryWrapper<User> lqw = new LambdaQueryWrapper<User>();
//范围查询 lt le gt ge eq between  
//范围查询 lt le  (不带等号 ) gt ge(带等号)  eq  between  
lqw.between(User::getAge, 10, 30);
List<User> userList = userDao.selectList(lqw);
System.out.println(userList);

注意:范围查询 lt le  (不带等号 ) gt ge(带等号)  eq  between  

模糊匹配 ,查信息,搜索新闻(非全文检索版:like匹配)代码示例:

LambdaQueryWrapper<User> lqw = new LambdaQueryWrapper<User>();
//模糊匹配 like likeRight  likeLeft
lqw.likeLeft(User::getName, "J");
List<User> userList = userDao.selectList(lqw);
System.out.println(userList);

统计报表(分组查询聚合函数),代码示例:

QueryWrapper<User> qw = new QueryWrapper<User>();
qw.select("gender","count(*) as nums");
qw.groupBy("gender");
List<Map<String, Object>> maps = userDao.selectMaps(qw);
System.out.println(maps);


http://www.kler.cn/a/377231.html

相关文章:

  • Spring Boot关闭时,如何确保内存里面的mq消息被消费完?
  • 深度学习-迁移学习
  • qt QListView详解
  • 《Rust语言圣经》Rust教程笔记17:2.Rust基础入门(2.6模式匹配)2.6.2解构Rust Option<T>
  • 将Beyond Compare添加到右键菜单中
  • 如何处理vue项目中的错误
  • web3.0 开发实践
  • 高速比较器选型与性能优化
  • Istio 服务网格深度解析
  • TOEIC 词汇专题:娱乐休闲篇
  • C#语言垃圾回收机制(GC)以及实现细节
  • 跨平台OFD、PDF文档预览UTS插件
  • CARAFE:基于内容感知的特征(FEatures)重新组装
  • C#WPF之快速理解MVVM模式
  • Ubuntu 24.04上启用 root 用户通过 SSH 和图形界面进行登录
  • 智能座舱相关术语全解及多模态交互在智能座舱中的应用
  • 用流量策略做多出口实验
  • 微服务架构面试内容整理-微服务架构的定义及优势
  • 新手BUG:在声明了返回值的函数中不写返回值
  • docker复现pytorch_cyclegan
  • 【代码随想录Day59】图论Part10
  • TCP/IP基础
  • 人工智能证书合集
  • 一 Spring6启示录
  • .NET 一款通过COM接口绕过UAC的工具
  • Java学习路线:JUL日志系统(一)日志框架介绍