大家好,又见面了,我是你们的朋友全栈君。
代码生成器的原理其实是非常简单的,主要可以分为下面两个步骤:
-
数据库元数据抓取
-
模板输出
第一步数据库元数据信息抓取
这里给大家提供些简单易于操作的思路,我们找到数据库连接中的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之类的模板技术也行.这里我先给羡慕提前准备好我们需要生成的模板,如下:
大家可以看我提前准备了六个模板,每个模板都有一些表达式的存在,这就是在获取表信息和列信息之后,需要填充进去的,然后通过模板技术动态渲染成我们需要的代码.
详细的步骤较为繁琐,大家可以看我的源码,有问题可以在下方提问.
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账号...