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

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

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

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

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

(0)


相关推荐

  • C++ vector初始化_vector>初始化

    C++ vector初始化_vector>初始化#include<iostream>#include<string>#include<vector>#include<deque>#include<list>#include<forward_list>#include<string>#include<array>usingnamespacestd;#defineLENGTH10typedefintTYPE;.

  • js 删除换行符

    js 删除换行符mymsg=mymsg.replace(/<\/?.+?>/g,””);//html2txt去掉html标记mymsg=mymsg.replace(/\n|\r/g,””);//去掉换行转载于:https://www.cnblogs.com/jerryLee/archive/2010/02/01/1661036.html…

  • 决策树—回归[通俗易懂]

    决策树—回归[通俗易懂]核心:划分点选择+输出值确定。一、概述决策树是一种基本的分类与回归方法,本文叙述的是回归部分。回归决策树主要指CART(classificationandregressiontree)算法,内部结点特征的取值为“是”和“否”,为二叉树结构。所谓回归,就是根据特征向量来决定对应的输出值。回归树就是将特征空间划分成若干单元,每一个划分单元有一个特定的输出。因为每个结点都是“是”…

  • HttpClient详细解释

    HttpClient详细解释Http协议的重要性相信不用我多说了,HttpClient相比传统JDK自带的URLConnection,增加了易用性和灵活性(具体区别,日后我们再讨论),它不仅是客户端发送Http请求变得容易,而且也方便了开发人员测试接口(基于Http协议的),即提高了开发的效率,也方便提高代码的健壮性。因此熟练掌握HttpClient是很重要的必修内容,掌握HttpClient后,相信对于Http协议的了解会

  • BIEE_biee报表日志

    BIEE_biee报表日志目录创建资料库创建物理模型创建逻辑模型创建展现模型保存资料库配置 OracleBIServer 使用新资料库在OracleAnswer中定义查询参考创建资料库BIEE的资料库(Repository)是一个后缀名为rpd的物理文件,其中存储了三类元数据:数据源物理模型,逻辑模型,以及展现模型。OracleBIServer是资料库的使用者:在前端,BI

    2022年10月22日
  • python安装包下载很慢_系统安装离线更新包太慢

    python安装包下载很慢_系统安装离线更新包太慢复制下载链接后打开迅雷即可 

    2022年10月25日

发表回复

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

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