iis服务器助手广告广告
返回顶部
首页 > 资讯 > 后端开发 > Python >如何利用反射生成 MyBatisPlus中QueryWrapper动态条件
  • 499
分享到

如何利用反射生成 MyBatisPlus中QueryWrapper动态条件

2024-04-02 19:04:59 499人浏览 泡泡鱼

Python 官方文档:入门教程 => 点击学习

摘要

目录1.问题2.优化方案1.问题 在MyBatisPlus中经常会用到如下所示的代码来构造查询条件: QueryWrapper<User> 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();
    }
}

到此这篇关于如何利用反射生成 mybatisPlus中QueryWrapper动态条件的文章就介绍到这了,更多相关反射生成 MyBatisPlus中QueryWrapper动态条件内容请搜索编程网以前的文章或继续浏览下面的相关文章希望大家以后多多支持编程网!

--结束END--

本文标题: 如何利用反射生成 MyBatisPlus中QueryWrapper动态条件

本文链接: https://www.lsjlt.com/news/139710.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
  • 如何利用反射生成 MyBatisPlus中QueryWrapper动态条件
    目录1.问题2.优化方案1.问题 在MyBatisPlus中经常会用到如下所示的代码来构造查询条件: QueryWrapper<User> queryWrapper = ...
    99+
    2024-04-02
  • 怎么利用反射生成MyBatisPlus中QueryWrapper动态条件
    这篇文章主要介绍了怎么利用反射生成MyBatisPlus中QueryWrapper动态条件的相关知识,内容详细易懂,操作简单快捷,具有一定借鉴价值,相信大家阅读完这篇怎么利用反射生成MyBatisPlus中QueryWrapper动态条件文...
    99+
    2023-06-29
  • MybatisPlus如何自动生成映射文件
    目录如何自动生成映射文件一、pom.xml二、MybatisPlusUtil工具类自动映射autoMappingBehavior与mapUnderscoreToCamelCaseau...
    99+
    2024-04-02
  • 怎么在java中利用反射生成对象
    这期内容当中小编将会给大家带来有关怎么在java中利用反射生成对象,文章内容丰富且以专业的角度为大家分析和叙述,阅读完这篇文章希望大家可以有所收获。Java是什么Java是一门面向对象编程语言,可以编写桌面应用程序、Web应用程序、分布式系...
    99+
    2023-06-14
  • 使用MyBatis-Generator如何自动生成映射文件
    目录MyBatis-Generator自动生成映射文件1、使用cmd命令方式生成2、使用maven方式生成3、如果开发工具为eclipse自动生成MyBatis映射文件工具问题MyB...
    99+
    2024-04-02
  • 如何在java中利用cglib动态生成一个实体bean
    如何在java中利用cglib动态生成一个实体bean?很多新手对此不是很清楚,为了帮助大家解决这个难题,下面小编将为大家详细讲解,有这方面需求的人可以来学习下,希望你能有所收获。maven依赖:<dependency>&nbs...
    99+
    2023-06-06
  • Vue.js如何利用v-for循环生成动态标签
    目录前言一、当写入数据为数组时二、当写入数据为对象时三、作用于标签属性和事件总结前言 使用v-for可以用于动态生成html标签。其实就是对于vue中属性是对象或者数组进行遍历生成新...
    99+
    2024-04-02
  • C#中如何使用反射和动态加载程序集
    C#中如何使用反射和动态加载程序集引言:在C#中,反射(Reflection)是一种强大的机制,它允许我们在运行时获取和操作程序的元数据,包括类型信息、成员信息等。而动态加载程序集则是通过反射来实现的一种常见应用,并且在一些特定场景中非常有...
    99+
    2023-10-22
    C# 反射 动态加载
  • 如何利用JS动态生成隔行换色HTML表格
    这篇文章将为大家详细讲解有关如何利用JS动态生成隔行换色HTML表格,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。用JS生成动态生成表格,行、列由用户输入,并使表格隔行换...
    99+
    2024-04-02
  • golang 如何使用反射动态修改变量值
    go 语言反射允许在运行时操控变量值,包括修改布尔值、整数、浮点数和字符串。通过获取变量的 value,可以调用 setbool、setint、setfloat 和 setstring ...
    99+
    2024-05-02
    反射 动态修改变量值 golang 字符串解析
  • 如何用Servlets动态生成图片
    这篇文章给大家介绍如何用Servlets动态生成图片,内容非常详细,感兴趣的小伙伴们可以参考借鉴,希望对大家能有所帮助。Image I/O 包及对 JDK 的要求   如果你的 servlet 要动态生成图象,首先你需要 image I/O...
    99+
    2023-06-03
  • Nodejs中怎么利用Kue动态生成PDF文档
    Nodejs中怎么利用Kue动态生成PDF文档,相信很多没有经验的人对此束手无策,为此本文总结了问题出现的原因和解决方法,通过这篇文章希望你能解决这个问题。先决条件您需要安装以下软件:Node.js最新稳定...
    99+
    2024-04-02
  • 如何利用Python自动生成PPT
    今天小编给大家分享一下如何利用Python自动生成PPT的相关知识点,内容详细,逻辑清晰,相信大部分人都还太了解这方面的知识,所以分享这篇文章给大家参考一下,希望大家阅读完这篇文章后有所收获,下面我们一起来了解一下吧。在日常工作中,PPT制...
    99+
    2023-07-02
  • golang 如何使用反射实现动态代理模式
    go中使用反射实现动态代理答案: 是的,可以通过反射在go中实现动态代理模式。步骤:创建自定义代理类型,包含目标对象引用和方法处理逻辑。为代理类型创建代理方法,在调用目标方法前或后执行额...
    99+
    2024-05-01
    golang 反射 动态代理
  • 如何使用PHP生成动态网页
    PHP是一种广泛应用于网页开发的脚本语言,可以与HTML结合使用,通过动态生成网页内容,提供更加丰富和个性化的用户体验。本文将介绍如何使用PHP生成动态网页,并提供具体的代码示例。第一步:设置PHP开发环境在开始编写PHP代码之前,需要确保...
    99+
    2023-10-21
    PHP动态网页 PHP生成网页 PHP网页编程
  • jquery如何动态生成标签绑定事件
    这篇文章主要为大家展示了“jquery如何动态生成标签绑定事件”,内容简而易懂,条理清晰,希望能够帮助大家解决疑惑,下面让小编带领大家一起研究并学习一下“jquery如何动态生成标签绑定事件”这篇文章吧。结...
    99+
    2024-04-02
  • 如何在Java中利用反射创建对象
    本篇文章给大家分享的是有关如何在Java中利用反射创建对象,小编觉得挺实用的,因此分享给大家学习,希望大家阅读完这篇文章后可以有所收获,话不多说,跟着小编一起来看看吧。一、什么是反射Java Reflaction in Action中的解释...
    99+
    2023-06-15
  • 如何在Go语言中利用反射功能
    标题:Go语言中的反射功能及代码示例 在Go语言中,反射(Reflection)是一种强大的机制,可以在运行时检查变量的类型和值,通过反射,我们可以动态地调用任意方法、修改变量的值,甚...
    99+
    2024-04-02
  • linq动态条件查询如何使用
    本篇内容主要讲解“linq动态条件查询如何使用”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“linq动态条件查询如何使用”吧!1,linq动态条件之构造表达式树private Expr...
    99+
    2023-06-17
  • 利用Java如何获取Mybatis动态生成的sql接口实现
    目录前言1、编写xml: SqlGenarate.mapper.xml2、定义接口3、实现接口总结前言 如果你有使用 JDBC 或其他类似框架的经验,你就能体会到根据不同条件拼接 S...
    99+
    2024-04-02
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作