如何利用反射生成 MyBatisPlus中QueryWrapper动态条件
作者:梁云亮 发布时间:2021-10-20 14:59:40
标签:MyBatisPlus,QueryWrapper,动态
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


猜你喜欢
- mybatis简单的CURD就不用多说了,网上相关博客文档一大堆。分析一下Mybatis里面的collection聚集查询。 假设一个班级有
- Android WebView的使用方法 Android app打开H5页一般要实现如下需求:1、打开指定url网页
- 前言在产品发布前夕,经常因为编写各类设计文档感到心碎,倒不是难,而是比较繁琐,举例来说,像编写数据库文档这种操作来说,对于新手,甚至很多有一
- JPA自定义VO类型转换(EntityUtils工具类)在JPA查询中,如果需要返回自定义的类,可以使用EntityUtils工具类,该类源
- 这篇文章主要介绍了springboot项目访问静态资源的配置代码实例,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习
- Prim算法介绍1.点睛在生成树的过程中,把已经在生成树中的节点看作一个集合,把剩下的节点看作另外一个集合,从连接两个集合的边中选择一条权值
- Android透明状态栏只有在4.4之后有。在代码中加入下面几行代码即可实现来源:http://www.cnblogs.com/wangxi
- 1. private void Form1_Load(object &
- 存首先初始化private SP sp;sp = new SP( context );存入数据第一个参数为上下文,第二个参数为key,第三个
- 本文实例讲述了C#获取文件创建时间的方法。分享给大家供大家参考。具体如下:C#获取文件创建时间,主要用到了FileInfo的Creattio
- 1.在C#中,类名首字母需大写。如:class Student2.在C#中Main()方法有四种形式:static void Main(st
- 引言前一段有幸参与到一个智能家居项目的开发,由于之前都没有过这方面的开发经验,所以对智能硬件的开发模式和技术栈都颇为好奇。智能可燃气体报警器
- 一、前言对于任何框架而言,在使用前都要进行一系列的初始化,MyBatis也不例外。二、MyBatis的初始化做了什么2.1 Mybatis的
- pageHelper分页失效及配置问题我在使用pageHelper的系统中加入mybatis-plus, 结果所有分页都失效了原因我这边的失
- Android 中RecycleView实现item的点击事件RecycleView现在已经越来越受到大家的重视,因为他既可以代替listV
- timer和timertask是jdk自带的定时任务实现,无需导入第三方jar包来完成1、指定多久之后执行此任务,注意:只会执行一次publ
- Android 中ScrollView嵌套GridView,ListView的实例在Android开发中,经常有一些UI需要进行固定styl
- 本文实例分析了C#泛型用法。分享给大家供大家参考。具体分析如下:这里演示如何创建具有单个类型参数的自定义泛型列表类,以及如何实现 IEnum
- 目录1.项目需求描述2.整体思路3.功能实现1.项目需求描述通过订单号获取某系统内订单的详细数据,不需要账号密码的登录验证,但有图片验证码的
- spring拓展 定义自己的namespace1.查看源码认识spring是怎么加载xml配置的1.1 spring是怎么创建对象的? 查看