Java代码生成器原理和编写

Java代码生成器原理和编写代码生成器的原理其实是非常简单的,主要可以分为下面两个步骤: 数据库元数据抓取 模板输出 第一步数据库元数据信息抓取这里给大家提供些简单易于操作的思路,我们找到数据库连接中的information_schema这个库,这个库就是元数据库,保存着其他库以及库表的信息,并且一直维护.我们想要做到根据数据库去动态生成代码,那么就需要拿到生成代码的对应的数据库,表,以及字段等信息.下面给大家提供一下获取数据库,获取数据库表,获取数据库表字段的SQL语句获取连接中的所有数据..

大家好,又见面了,我是你们的朋友全栈君。

代码生成器的原理其实是非常简单的,主要可以分为下面两个步骤:

  1. 数据库元数据抓取

  2. 模板输出

 

第一步数据库元数据信息抓取

这里给大家提供些简单易于操作的思路,我们找到数据库连接中的information_schema这个库,这个库就是元数据库,保存着其他库以及库表的信息,并且一直维护.

我们想要做到根据数据库去动态生成代码,那么就需要拿到生成代码的对应的数据库,表,以及字段等信息.下面给大家提供一下获取数据库,获取数据库表,获取数据库表字段的SQL语句

 

获取连接中的所有数据库

SELECT SCHEMA_NAME schemaName, DEFAULT_CHARACTER_SET_NAME characterName, DEFAULT_COLLATION_NAME collationName FROM information_schema.SCHEMATA

获取数据库表

SELECT table_name tableName,ENGINE,table_comment tableComment,create_time createTime FROM information_schema. TABLES WHERE table_schema = (SELECT DATABASE())

获取数据库表的列信息

select column_name columnName, data_type dataType, column_comment columnComment, column_key columnKey, extra from information_schema.columns\n" +
                " \t\t\twhere table_name = '"+tableName+"' and table_schema = (select database()) order by ordinal_position

 

现在大家能获取到数据库,数据库表以及列的信息,那么根据一些模板技术是不是可以把这些表信息,列信息输出成文件呢,可以思考一下.

 

第二步使用模板技术输出文件

这里我使用apache的velocity模板渲染技术,大家也可以使用freemark之类的模板技术也行.这里我先给羡慕提前准备好我们需要生成的模板,如下:

Java代码生成器原理和编写

 

大家可以看我提前准备了六个模板,每个模板都有一些表达式的存在,这就是在获取表信息和列信息之后,需要填充进去的,然后通过模板技术动态渲染成我们需要的代码.

 

详细的步骤较为繁琐,大家可以看我的源码,有问题可以在下方提问.

B/S架构代码: https://gitee.com/lijunnb666/apollo-generator-fast

C/S架构代码: https://gitee.com/lijunnb666/apollo-generator

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

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/136617.html原文链接:https://javaforall.net

(0)
上一篇 2022年5月4日 下午6:20
下一篇 2022年5月4日 下午6:20


相关推荐

  • Linux安装jdk(两种方式)

    Linux安装jdk(两种方式)最近在研究大数据方面的东西 业务场景是从设备采集数据经过处理然后存放 DB 建设上面的环境第一步肯定是安装 jdk 所以和大家一起学一下基本知识 centos7 5 安装 jdk1 8 安装 jdk 有两种方法 手动安装 yum 安装 yum 安装如下 1 查询要安装 jdk 的版本 命令 yum ylistjava 2 安装 jdk1 8 命令 yuminst

    2026年3月18日
    2
  • activiti工作流框架_springboot工作流框架

    activiti工作流框架_springboot工作流框架工作流Activiti是一个项目的名称,Alfresco软件在2010年5月17日宣布Activiti业务流程管理(BPM)开源项目的正式启动,其首席架构师由业务流程管理BPM的专家TomBaeyens担任。Activiti项目是一项新的基于Apache许可的开源BPM平台,从基础开始构建,旨在提供支持新的BPMN2.0标准,包括支持对象管理组(OMG),面对新技术的机遇,…

    2026年4月15日
    3
  • 搜索引擎使用技巧

    1、双引号把搜索词放在双引号中,代表完全匹配搜索,也就是说搜索结果返回的页面包含双引号中出现的所有的词,连顺序也必须完全匹配。百度和Google都支持这个指令。例如搜索:“Python”。2、减号减号代表搜索不包含减号后面的词的页面。使用这个指令时减号前面必须是空格,减号后面没有空格,紧跟着需要排除的词。Google和bd都支持这个指令。例如:搜索-引擎返回的则是包含“搜索”这…

    2022年4月5日
    62
  • mysqlnd cannot connect to MySQL 4.1+ using the …

    mysqlnd cannot connect to MySQL 4.1+ using the …

    2021年8月20日
    55
  • Idea激活码最新教程2020.3.4版本,永久有效激活码,亲测可用,记得收藏

    Idea激活码最新教程2020.3.4版本,永久有效激活码,亲测可用,记得收藏Idea 激活码教程永久有效 2020 3 4 激活码教程 Windows 版永久激活 持续更新 Idea 激活码 2020 3 4 成功激活

    2025年5月22日
    4
  • 什么是虚拟DOM

    什么是虚拟DOM什么是虚拟 DOM virtualDOM 虚拟 DOM 用普通 js 对象来描述 DOM 结构 因为不是真实 DOM 所以称之为虚拟 DOM 虚拟 dom 是相对于浏览器所渲染出来的真实 dom 而言的 在 react vue 等技术出现之前 我们要改变页面展示的内容只能通过遍历查询 dom 树的方式找到需要修改的 dom 然后修改样式行为或者结构 来达到更新 ui 的目的 这种方式相当消耗计算资源 因为每次查询 dom 几乎都需要遍历整颗 dom 树 如果建立一个与 dom 树对应的虚拟 dom 对象 js 对象

    2026年3月19日
    2

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

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