如何利用反射生成 MyBatisPlus中QueryWrapper动态条件
作者:梁云亮 时间:2021-10-20 14:59:40
1.问题
在MyBatisPlus中经常会用到如下所示的代码来构造查询条件:
QueryWrapper<User> queryWrapper = new QueryWrapper<>();
if (userQuery.getId() != null) {
queryWrapper.eq("id", userQuery.getId());
}
if (userQuery.getName() != null) {
queryWrapper.like("name", userQuery.getName());
}
if (userQuery.getNickname() != null) {
queryWrapper.like("nickname", userQuery.getNickname());
}
if (userQuery.getAccount() != null) {
queryWrapper.eq("account", userQuery.getAccount());
}
if (userQuery.getGender() != null) {
queryWrapper.eq("gender", userQuery.getGender());
}
if (userQuery.getBirth1() != null) {
queryWrapper.ge("birth", userQuery.getBirth1());
}
if (userQuery.getBirth2() != null) {
queryWrapper.le("birth", userQuery.getBirth2());
}
if (userQuery.getTel() != null) {
queryWrapper.eq("tel", userQuery.getTel());
}
if (userQuery.getEmail() != null) {
queryWrapper.eq("email", userQuery.getEmail());
}
if (userQuery.getQq() != null) {
queryWrapper.eq("qq", userQuery.getQq());
}
if (userQuery.getWechat() != null) {
queryWrapper.eq("wechat", userQuery.getWechat());
}
if (userQuery.getHomePage() != null) {
queryWrapper.eq("home_page", userQuery.getHomePage());
}
//.........
baseMapper.selectPage(page, queryWrapper);
大量这样的代码,可以通过如下所示的反射技术生成,从而一劳永安逸,
2.优化方案
public class APP{
public static void main(String[] args) throws Exception {
QueryWrapper<Dept> queryWrapper = new QueryWrapper<>();
Dept dept = Dept.builder()
.deptno(1234)
// .dname("sales")
.loc("NEWYORK")
.build();
Method[] methods = Dept.class.getDeclaredMethods();
for (Method method : methods) {
String methodName = method.getName();
if (methodName.contains("get")) {
Object res = method.invoke(dept, null);
if(res != null){
String columnName = getColumnName(methodName);
queryWrapper.eq(columnName,res);
}
}
}
System.out.println(queryWrapper);//在此处设置断点,可以查看保存到QueryWrapper中的值
}
// 根据getter方法名得到对应表的字段名
public static String getColumnName(String name) {
StringBuffer sb = new StringBuffer();
name = name.substring(3, name.length()); //去掉get前缀
char[] chars = name.toCharArray();
for (int i = 0; i < chars.length; i++) {
char item = chars[i];
if (item > 65 && item < 90) {//大写字母
sb.append("_");
sb.append((char)(item+32));
}else {
sb.append(item);
}
}
return sb.deleteCharAt(0).toString();
}
}
来源:https://blog.51cto.com/lianghecai/5011926
标签:MyBatisPlus,QueryWrapper,动态
![](/images/zang.png)
![](/images/jiucuo.png)
猜你喜欢
Qt之调用C#的动态库的解决方法
2023-07-22 03:42:45
![](https://img.aspxhome.com/file/2023/1/67061_0s.png)
Android中获取资源 id 及资源 id 的动态获取
2023-06-30 04:38:06
spring retry实现方法请求重试的使用步骤
2021-12-31 15:11:11
Java 实现二叉搜索树的查找、插入、删除、遍历
2023-10-04 05:37:39
![](https://img.aspxhome.com/file/2023/5/83025_0s.png)
Spring多个数据源配置详解
2023-09-20 18:22:18
![](https://img.aspxhome.com/file/2023/6/79936_0s.png)
值得收藏的2017年Java开发岗位面试题
2023-11-29 15:22:01
Spring Cloud中FeignClient实现文件上传功能
2023-06-23 07:57:09
mybatis-plus乐观锁实现方式详解
2022-09-27 16:12:27
![](https://img.aspxhome.com/file/2023/5/66175_0s.png)
详解idea maven nexus 常见命令配置
2021-06-07 18:29:03
![](https://img.aspxhome.com/file/2023/1/62731_0s.png)
DecimalFormat多种用法详解
2022-11-13 15:06:52
Java基础之finally语句与return语句详解
2021-11-27 19:21:22
你真的了解Java的多线程方法吗
2022-02-01 22:55:40
![](https://img.aspxhome.com/file/2023/4/69344_0s.png)
深入了解Java ServletContext
2023-11-08 22:36:27
![](https://img.aspxhome.com/file/2023/7/59387_0s.png)
基于Mybatis plus 自动代码生成器的实现代码
2023-11-24 10:40:51
Java中List使用stream流转成map的几种方式详解
2022-07-31 21:46:12
java实现滑动验证解锁
2023-06-02 12:16:36
![](https://img.aspxhome.com/file/2023/4/74894_0s.jpg)
带着新人看java虚拟机01(推荐)
2023-05-28 04:38:16
![](https://img.aspxhome.com/file/2023/7/78047_0s.png)
Springboot启动不检查JPA的数据源配置方式
2022-10-10 06:47:05
![](https://img.aspxhome.com/file/2023/4/68774_0s.jpg)
GSON实现Java对象与JSON格式对象相互转换的完全教程
2023-11-23 09:23:37
解决SpringBoot web项目启动后立即关闭的问题
2023-07-26 02:33:37
![](https://img.aspxhome.com/file/2023/9/64909_0s.png)