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

  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之类的模板技术也行.这里我先给羡慕提前准备好我们需要生成的模板,如下:

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

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

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

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

Java代码生成器原理和编写相关推荐

  1. 在java web项目中编写自己的代码生成器

    在java web项目中编写自己的代码生成器 转载于:https://www.cnblogs.com/punisher/p/5909943.html

  2. java制作网站的原理_代码生成器原理

    代码生成器原理很简单,用一句话概括就是:将数据库字段转换成Java字段并输出内容. 如下图所示: 因此,首先需要做的是获取表信息以及表的字段信息,一般有两种方式,第一种:连接到数据库,执行相关SQL, ...

  3. 【Java 虚拟机原理】Class 字节码二进制文件分析 七 ( 局部变量表分析 )

    文章目录 前言 一.编译生成带局部变量表的字节码文件 二.局部变量表 前言 上一篇博客 [Java 虚拟机原理]Class 字节码二进制文件分析 二 ( 常量池位置 | 常量池结构 | tag | i ...

  4. java native方法_并发系列-native函数回调Java方法原理实践

    写在前面 上一篇分享了Java调用native函数过程原理实践,文章最后留了一个问题,本章主要对C程序回调我们的Java程序原理进行实践. 调用C程序之后他是怎么知道来调用我们我们的哪个方法?又是如何 ...

  5. Java类加载原理解析(转)

    1       基本信息 摘要: 每个java开发人员对java.lang.ClassNotFoundExcetpion这个异常肯定都不陌生,这背后就涉及到了java技术体系中的类加载.Java的类加 ...

  6. 查找算法--Java实例/原理

    原文网址:查找算法--Java实例/原理_IT利刃出鞘的博客-CSDN博客 简介 本文用Java实例介绍查找算法及其原理. 本内容也是Java后端面试常见的问题. 查找定义 查找定义:根据给定的某个值 ...

  7. Java技术原理详解

    一.Java 运行原理  1.高级语言运行过程  在程序真正运行在CPU上之前,必须要让OS的kernel理解我们在编辑器或者IDE里根据每种语言的语法规则敲入的源代码,kernel才能做出相关的调度 ...

  8. Java类加载原理解析

    Java类加载原理解析 基本信息摘要: 每个java开发人员对java.lang.ClassNotFoundExcetpion这个异常肯定都不陌生,这背后就涉及到了java技术体系中的类加载.Java ...

  9. 必知必会系列-JAVA虚拟机原理

    系列文章 必知必会系列-Spring技术原理 必知必会系列-JAVA虚拟机原理 必知必会系列-Redis技术原理 引言 随着技术的不断演进,在不同时间阶段都会有不同的技术产物,那么如何快速的学习和掌握 ...

  10. 08从零开始学Java之记事本怎么编写Java代码?

    作者:孙玉昌,昵称[ 一一哥],另外[ 壹壹哥]也是我哦 CSDN博客专家.万粉博主.阿里云专家博主.掘金优质作者 配套开源项目资料 GitHub地址: https://github.com/SunL ...

最新文章

  1. 26个导航设计非常独特的网站案例欣赏
  2. C4C的导航菜单的问题,disable这个属性,就会变成正常的两级菜单
  3. linux系统嵌入式编译环境,Ubuntu 12.04嵌入式交叉编译环境arm-linux-gcc搭建过程图解...
  4. php登录个性验证码,PHP七种不同的个性创意验证码例子
  5. 叮咚买菜的数据应用之路,互联网公司的数据决策平台有何不同
  6. openwrt挂载u盘(ntfs)_如何在 Bitcoin 的源码基础上生成一条自己的链 08:将bitcoin移植到openwrt...
  7. 程序员面试金典——3.6双栈排序
  8. 基于zookeeper的分布式锁实现原理是什么?
  9. 周立功DTU+温度传感器,ZWS物联网平台尝试
  10. 阿里云服务器操作系统怎么选择?
  11. WIFI 认证加密模式介绍 理解无线安全
  12. 非常规方法彻底删除System Volume Information.exe
  13. Java岗大厂面试百日冲刺 - 日积月累,每日三题【Day37】—— 并发编程3
  14. stylecloud ,wordcloud 库学习及使用例子
  15. 《web前端面试题》第一问-如何快速居中对齐?
  16. 第七天 03.python环境安装
  17. ZZNUOJ_C语言1024:计算字母序号(完整代码)
  18. 天润融通java面试_【天润融通怎么样?】-看准网
  19. SpringBoot如何映射图片地址
  20. 计算机网络基础知识(笔记)

热门文章

  1. 欺骗的艺术——谈谈社会工程学
  2. 侯捷老师——STL源码剖析
  3. java捕鱼达人代码java捕鱼游戏代码
  4. python将文本(txt)转excel(xls)
  5. Python编程:数据可视化《Python编程:从入门到实践 第2版》笔记
  6. 30个Python小游戏,小白练手,我都能玩一天【内附源码】
  7. 私生子与假婊子——谈中国手机JAVA游戏
  8. Python设计模式(七)【命令模式】
  9. c语言王者荣耀制作,易语言制作王者荣耀刷金币脚本的代码
  10. 虚拟 IP原理(动态 IP 、固定 IP 、实体 IP)