首页 技术 正文
技术 2022年11月10日
0 收藏 423 点赞 4,881 浏览 2332 个字

转载自

MyBatis-Plus QueryWrapper及LambdaQueryWrapper的使用

LambdaQueryWrapper

https://blog.csdn.net/lt326030434/article/details/106571670

LambdaQueryWrapper条件构造器方法对应Sql

setSqlSelect SELECT 查询字段 举例
where WHERE 语句,拼接 + WHERE 条件  
and AND 语句,拼接 + AND 字段=值  
andNew AND 语句,拼接 + AND (字段=值)  
or OR 语句,拼接 + OR 字段=值 .eq(” name “,” 木 子 “). or ( ). eq (” id “, 1 ) => name=“木子” or id=1 注意事项:主动调用or表示下一个方法不是and连接,不调用默认为使用and连接
orNew OR 语句,拼接 + OR (字段=值)  
eq 等于= .eq(“name”,“木子”) => name=“木子”
allEq 基于 map 内容等于=  
ne 不等于<>  
gt 大于>  
ge 大于等于>=  
lt 小于<  
le 小于等于<=  
like 模糊查询 LIKE .like(“name”,“木子”) => name like ‘%木子%’
notLike NOT LIKE模糊查询  
in IN 查询 .in(“age”,{1,2,3}) => age in (1,2,3)
notIn NOT IN 查询  
isNull NULL 值查询  
isNotNull IS NOT NULL  
groupBy 分组 GROUP BY  
having HAVING 关键词  
orderBy 排序 ORDER BY  
orderAsc Asc 排序 ORDER BY  
orderDesc DESC 排序 ORDER BY  
exists EXISTS 条件语句  
notExists NOT EXISTS 条件语句  
between BETWEEN 条件语句 .between (“age”,1,2) => age between 1 and 2
notBetween NOT BETWEEN 条件语句  
addFilter 自由拼接 SQL  
last 拼接在最后,例如:last(“LIMIT 1”)  

假如我们有一张banner_item表,现需要通过banner_id查出所有数据(查询List)

@Data
public class BannerItem { private Long id; private String name; private String img; private String keyword; private Integer type; private Long bannerId;
}
  • QueryWrapper

最基础的使用方式是这样

// 查询条件构造器
QueryWrapper<BannerItem> wrapper = new QueryWrapper<>();
wrapper.eq("banner_id", id);
// 查询操作
List<BannerItem> bannerItems = bannerItemMapper.selectList(wrapper);

 

然后我们可以引入lambda,避免我们在代码中写类似的于banner_id的硬编码

QueryWrapper<BannerItem> wrapper = new QueryWrapper<>();
wrapper.lambda().eq(BannerItem::getBannerId, id);
List<BannerItem> bannerItems = bannerItemMapper.selectList(wrapper);
  • LambdaQueryWrapper

为了简化lambda的使用,我们可以改写成LambdaQueryWrapper构造器,语法如下:

LambdaQueryWrapper<BannerItem> wrapper = new QueryWrapper<BannerItem>().lambda();
wrapper.eq(BannerItem::getBannerId, id);
List<BannerItem> bannerItems = bannerItemMapper.selectList(wrapper);

 

我们可以再次将QueryWrapper<BannerItem>.lambda()简化,变成这个样子

LambdaQueryWrapper<BannerItem> wrapper = new LambdaQueryWrapper<>();
wrapper.eq(BannerItem::getBannerId, id);
List<BannerItem> bannerItems = bannerItemMapper.selectList(wrapper);

 

  • 链式查询

MyBatis-Plus还提供了一种链式查询的方式,和上面的代码效果一样。
但是这种写法偏向于炫技,可读性没有上面的代码强,大家可以根据需要自行选择方式。

List<BannerItem> bannerItems = new LambdaQueryChainWrapper<>(bannerItemMapper)
.eq(BannerItem::getBannerId, id)
.list();

 

如果只想查询一条记录,例如通过id查询某条记录的详情,使用.one()即可,例如

BannerItem bannerItem = new LambdaQueryChainWrapper<>(bannerItemMapper)
.eq(BannerItem::getId, id)
.one();

 

一个使用较多的项目模板 https://gitee.com/xqnode/x-admin

 

MyBatis-Plus QueryWrapper及LambdaQueryWrapper的使用

相关推荐
python开发_常用的python模块及安装方法
adodb:我们领导推荐的数据库连接组件bsddb3:BerkeleyDB的连接组件Cheetah-1.0:我比较喜欢这个版本的cheeta…
日期:2022-11-24 点赞:878 阅读:9,493
Educational Codeforces Round 11 C. Hard Process 二分
C. Hard Process题目连接:http://www.codeforces.com/contest/660/problem/CDes…
日期:2022-11-24 点赞:807 阅读:5,907
下载Ubuntn 17.04 内核源代码
zengkefu@server1:/usr/src$ uname -aLinux server1 4.10.0-19-generic #21…
日期:2022-11-24 点赞:569 阅读:6,740
可用Active Desktop Calendar V7.86 注册码序列号
可用Active Desktop Calendar V7.86 注册码序列号Name: www.greendown.cn Code: &nb…
日期:2022-11-24 点赞:733 阅读:6,495
Android调用系统相机、自定义相机、处理大图片
Android调用系统相机和自定义相机实例本博文主要是介绍了android上使用相机进行拍照并显示的两种方式,并且由于涉及到要把拍到的照片显…
日期:2022-11-24 点赞:512 阅读:8,133
Struts的使用
一、Struts2的获取  Struts的官方网站为:http://struts.apache.org/  下载完Struts2的jar包,…
日期:2022-11-24 点赞:671 阅读:5,297