# gen_code
**Repository Path**: javahao/gen_code
## Basic Information
- **Project Name**: gen_code
- **Description**: 打造中国最好用的跨语言通用版代码生成器,让“程序猿”有更多的时间陪老婆孩子,让你爱上写代码。
- **Primary Language**: Java
- **License**: Apache-2.0
- **Default Branch**: master
- **Homepage**: None
- **GVP Project**: No
## Statistics
- **Stars**: 21
- **Forks**: 3
- **Created**: 2017-07-03
- **Last Updated**: 2023-11-23
## Categories & Tags
**Categories**: Uncategorized
**Tags**: None
## README
# gen_code
打造中国最好用的代码生成器,让“程序猿”有更多的时间陪老婆孩子,让你爱上写代码。
### 版本升级
* 1.6(2018-05-17)升级
a.升级关系表定义变量名称以及备注信息
* 1.6(2018-01-01)升级信息
a、优化了freemark的变量加载侧率
c、支持表多关系生成侧率
d、增加了模板配置案例
* 1.5版本(2017-08-31)
a、增加了表配置项自定义扩展内部变量,方便扩展属性
c、常规代码优化
* 1.4版本(2017-08-27)
a、修复多表关系代码生成bug
b、常规代码优化
* 1.3版本(2017-08-01)
a、增加生成文件路径变量控制,优化代码
b、增加生成代码模板
c、完善生成路径不存在自动创建模块文件夹
* 1.1版本(2017-07-08)
a、优化生成器功能,优化代码
b、增加代码生成器模板引擎插件支持
c、增加表变量定义,可以满足复杂表关系的处理,例如一对多,多对一,多对多的代码生成
d、将jar上传maven中央仓库,之后可以将jar包依赖入项目进行使用
e、完善描述文档
* 1.0版本(2017-07-02)
a、增加代码生成器的基本功能
此为生成器源码,可以将生成器程序化,参考格式如下:
## 生成器打包
|-----gen-folder 默认生成文件存放目录文件,可通过core-config.xml修改
|-----jre jre运行环境
|-----lib 程序运行依赖的lib包
|-----driver 增加其他数据库支持,将驱动放置此包配置core-config.xml中dialog即可
|-----plugins freemarker插件扩展包,增加模板自定义标签可将实现类打包jar放入此包修改配置文件freemarker的节点
|-----template FreeMarker模板文件存储路径,可通过core-config.xml修改
|-----template-bak 作者模板备份,供开发使用者参考编写
|-----core-config.xml 全局文件配置
|-----gencode-1.0-RELEASE.jar 生成器主要程序
|-----run.bat windows运行启动程序
|-----run.sh linux运行启动程序
|-----READEME.md 使用说明
## 注意
如果在ide中运行生成器的话需要单独在`vm options`中单独设置`-Djava.ext.dirs=./lib;./driver;./plugins`即可
## 原理
本程序使用FreeMarker模板引擎,采用数据库反向生成的思想研发的代码生成器,初次使用建议先阅读READEME.TXT以及core-config.xml配置文件
## 支持
目前测试通过数据库有`mysql`、`postgresql`、`oracle`等关系型数据库,目前还不支持文档型数据库,如果使用者使用其他关系型数据库,请自行加入jar包驱动以及增加dialog配置即可
## 插件支持
编写模板的过程中可以自定义一些FreeMarker的插件,只需要实现TemplateMethodModelEx类并且将实现类打包放到plugins文件夹下,并且将插件配置到core-config.xml文件的freemarker节点即可在模板中使用
## Maven依赖支持
com.github.javahaohao
gen_code
1.6-RELEASE
将依赖引入项目中,并按照core-config.xml进行配置即可
## 使用方式
* 步骤大体如下:
* 1、根据各自业务场景配置template下的模板文件
* 2、修改core-config.xml配置文件,进行个性化配置
* 3、运行run.bat/run.sh即可生成代码
* 模板变量属性参考
* 表变量属性
```java
private String tableCat;
/**
* 表所属数据库
*/
private String tableSchema;
/**
* 表名称
*/
private String tableName;
/**
* 表类型
*/
private String tableType;
/**
* 表引擎类型
*/
private String engine;
/**
* 表备注
*/
private String tableComment;
/**
* 拥有的字段
*/
private List columns = new ArrayList();
/**
* 生成表的配置
*/
private TableConfig tableConfig;
```
* 字段变量属性
```java
/**
* 字段名称
*/
private String columnName;
/**
* 字段类型char(30)
*/
private String columnType;
/**
* 数据类型char
*/
private String dataType;
/**
* 字段备注
*/
private String columnComment;
/**
* 键值类型
*/
private String columnKey;
/**
* 是否为空
*/
private boolean nullable;
/**
* 字段长度
*/
private Long columnLength;
/**
* 所属表
*/
private Table table;
/**
* 是否主键
*/
private boolean primary;
/**
* 是否自增长
*/
private boolean autoincrement;
private boolean generatedColumn;
/**
* 表中字段的索引位置
*/
private int ordinalPosition;
```
## 使用技巧
* 1、使用过程中的配置各种路径的时候可以采用相对路径的方式,将生成的代码直接定位到自己的工程里面,省去了繁琐的拷贝时间
* 2、灵活的运用变量可以变相的解决一些复杂性的问题
* 3、模板编写属于自由发挥的模块,模板编写过程要多运用FreeMarker的内置函数去实现
* 4、前后端都做的“宝宝们”,尽量连前台的模板一并写出,即可前后端一并生成,如果有特殊需求,进行微调即可
* 5、此代码生成器虽然是“数据库反向生成思想”,但是也可以摆脱数据库,配置一些非开发功能模板,采用配置变量作为数据源进行使用
* 6、此点很重要,代码生成器使用依赖表的注释以及字段的注释,请设计表的过程尽量完善表的设计,生成的代码更友好
## 后续功能
1、目前生成器1.0版本只支持基本的单表反向生成策略,后续有时间我会将有表关系的生成策略加上(策略已加上)
2、目前生成器1.0版本只支持关系型数据库,像一些文档型非关系型数据库还不支持,后续会加上
## 联系方式
AUTH:JavaHao
QQ:353475081
QQ群:424890813
Email:353475081@qq.com