反射之动态拼接sql字符串「建议收藏」

反射之动态拼接sql字符串「建议收藏」反射之动态拼接sql字符串前言自己在学习JDBC连接数据库,不用框架手动实现时,个人觉得反射动态拼接sql的思想很好,当然了大家伙觉得好才是真的好(广州好迪,手动狗头),所以才有了本文对该知识点梳理与总结。分享给大家,下面开始步入文章的正文,亲们不要掉队。正文…

大家好,又见面了,我是你们的朋友全栈君。如果您正在找激活码,请点击查看最新教程,关注关注公众号 “全栈程序员社区” 获取激活教程,可能之前旧版本教程已经失效.最新Idea2022.1教程亲测有效,一键激活。

Jetbrains全家桶1年46,售后保障稳定

反射之动态拼接sql字符串的实现

前言

自己在学习JDBC连接数据库,不用框架手动实现时,个人觉得反射动态拼接sql的思想很好,当然了大家伙觉得好才是真的好(广州好迪,手动狗头),所以才有了本文对该知识点梳理与总结。分享给大家,下面开始步入文章的正文,亲们不要掉队。
(嘘~看这里:使用的开发工具是IDEA哦)
在这里插入图片描述

正文

首先带领大家理解一下我的思路,遥想当时我想了几个小时不知如何下手,无所事事敲键盘,未曾想用最简单的方式反而有了结果。

在这里插入图片描述

具体实现步骤

  • JDBC连接数据库
  • 根据数据库表中字段创建实体类

亲们,上面这两步我就不说了,不是本文的重点不做说明,有时间会总结JDBC连接数据库。

  • 如何实现动态sql语句的拼接
    重点来了搬好小板凳坐好!
    在这里插入图片描述

小小脑袋讲故事给大家听

我是小朋友望舒,在很久很久以前,我的梦想是实现动态拼接sql,既然动态拼接,我就要有东西来存放它,那就整两条String(字符串)(不妨给他们起名sqlSentence,sqlResult)把他们拼接成sql来展现我拼接后的字符串。不用多久,我就会升职加薪、当上总经理、出任CEO、迎娶白富美、走上人生巅峰,想想还有点小激动…)

公式 sql = sqlSentence + sqlResult

         String sqlSentence = "";
         String sqlResult = "";

Jetbrains全家桶1年46,售后保障稳定

接下来就是反射原理地实现了(不得不说反射真的很强大),从反射的百宝箱里面找到了两个工具:getClass()[获得类]、getSimpleName()[获得类的名字],拿着他俩去我家后院一顿操作:

        Class<?> aClass = webpage.getClass();
        String table = aClass.getSimpleName();

我发现了后院(数据库中的)里的神奇宝物(webpage表,实际就是实体类!) 把他们sout(懂得都懂,不懂得问我)一下就是这个东东
在这里插入图片描述
隐隐约约看见宝物上印着一幅画~~ 喏,就是这个(毫无保留展示给亲们)请添加图片描述

差点以为自己的梦想实现了,却发现自己要找的东西还没有出现。于是我又拿出了百宝箱的另外两件工具getDeclaredFields()[获得某个属性对象]、getName()[获得类的完整路径名字];用它们探索宝物的奥秘!

Field[] fields = aClass.getDeclaredFields();
            String s1 = "";
            String v1 = "";
            for (Field f : fields) { 
   
                f.setAccessible(true);
                if (f.get(webpage)==null){ 
   
                    return;
                }else{ 
   
                    sqlSentence = sqlSentence + f.getName() + ",";
                    f.setAccessible(true);
                    sqlResult = sqlResult + "'" + f.get(webpage) + "'" + ",";
               }
            }

(这里我解释一下:上面几行代码原理很简单,如果字段不为空就通过反射拿到实体类属性,换句话说就是拿到数据库表中字段,然后用foreach循环遍历出来,并用单引号” ’ “和” , “隔开就达到了下面这样的效果)
在这里插入图片描述
我拿出我的✂[substring()方法]把后面多余的逗号剪掉就会更好看一点,给我的✂亮个相,不要嫌它丑

            sqlSentence = sqlSentence .substring(0, s1.length() - 1);
            sqlResult = sqlResult .substring(0, v1.length() - 1);

我在院子里跑累了,就打算躺下来休息休息,随手把它们(sqlSentence,sqlResult)放在了床边,我就昏昏欲睡了。。。。。。
不知睡了多久,刹那间一道强光闪现,我揉了揉睡眼惺忪的眼睛— —没错 宝物合二为一了!梦想实现了!!(幸福来得太突然,一时间竟不知所措)
在这里插入图片描述

            String sql = "insert into " + table + "(" + sqlSentence + ") values (" + sqlResult + ")";
            System.out.println(sql);

打印在控制台如下

在这里插入图片描述
自此,有了这件宝物望舒过上了愉快幸福的996生活~~~
完结!撒花!!!

结语

故事讲完了,第一次尝试着用这种方式来描述问题,还请大家多多指正。
我是望舒,Salute!!!

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。

发布者:全栈程序员-用户IM,转载请注明出处:http://www.javaforall.cn/234741.html原文链接:http://www.javaforall.cn

【正版授权,激活自己账号】: Jetbrains全家桶Ide使用,1年售后保障,每天仅需1毛

【官方授权 正版激活】: 官方授权 正版激活 支持Jetbrains家族下所有IDE 使用个人JB账号...

(0)
blank

相关推荐

  • 全面理解.htaccess语法中RewriteCond和RewriteRule意义

    全面理解.htaccess语法中RewriteCond和RewriteRule意义全面理解.htaccess语法中RewriteCond和RewriteRule意义.htaccess配置文件可以通过RewriteCond和RewriteRule实现伪静态。RewriteCond的语法//含义:当什么东西匹配某种模式,则..RewriteCondTestStringCondPattern[Flags]RewriteCond%{HTTP_H…

  • 图书管理系统C语言_c语言图书信息管理系统

    图书管理系统C语言_c语言图书信息管理系统《C语言图书管理系统代码》由会员分享,可在线阅读,更多相关《C语言图书管理系统代码(3页珍藏版)》请在人人文库网上搜索。1、include#includenum,ptr-bname,ptr-wname,ptr-press,ptr-sort,ptr-time,ptr-price);printf(=n);f*n,p-num,p-bname,p-wname,p-press,p-sort,p-time…

    2022年10月11日
  • 解决smplayer中文字幕乱码

    解决smplayer中文字幕乱码首先,打开选项->首选项:选择字幕选项卡。找到“默认字符编码”选项,在下拉框中选择“简体中文(cp936)”再打开“字体和颜色”页卡(上边),选择“系统字体”在下拉选框中选择一种简体中文字体转载于:https://www.cnblogs.com/hbxtght/archive/2011/05/18/2049938.html…

  • npn饱和截止放大怎么判断_二极管饱和状态

    npn饱和截止放大怎么判断_二极管饱和状态幼儿园水平理解三极管截止、放大和饱和状态!书上看不懂,听课听不懂的过来!绕不开的三极管结构以NPN为例,晶体三极管的结构,这是很多人不想看的,但是确实是非常重要的!不看结构是理解不了工作原理的!(这样记忆:N是negative,负,代表多子为电子;P是positive,正,代表多子为空穴)注意观察三极管的结构,有助于理解工作时的状态。两张图结合起来看,略作解释:1.图中空心为空穴带正…

  • Apache 配置与应用

    Apache 配置与应用目录引言一、Apache连接保持二、Apache的访问控制1.客户机地址限制2.用户授权控制2.1创建用户认证数据文件2.2添加用户授权配置2.3验证用户访问授权三、Apache日志分割1.Apache自带rotatelogs分割工具2.使用第三方工具cronolog分割四、AWStats日志分析1.部署AWStats分析系统2.访问AWStats分析系统总结引言ApacheHTTPServer之所以受到众多企业的青睐,得益于其源代码开源,跨平台、功能

  • 4G网络架构_三大网络架构

    4G网络架构_三大网络架构1,4G是第四代移动通信技术,该技术包括TD-LTE和FDD-LTE两种制式,严格意义上来讲LTE只是3.9G,只有升级版的LTEAdvanced才满足国际电信联盟对4G的要求。4G是集3G与WLAN于一体,并能够快速传输数据、高质量、音频、视频和图像等。4G能够以100Mbps以上的速度下载,比目前的家用宽带ADSL(4兆)快25倍,并能够满足几乎所有用户对于无线服务的要求。

发表回复

您的电子邮箱地址不会被公开。

关注全栈程序员社区公众号