代码生成一步到位
一、背景与问题
笔者认为代码生成在某些情景下非常有用,但是在某些情景下还是建议慎用,因为不是手敲出的代码毕竟缺少了一个思考的过程,会很容易产生bug,相比于速度和bug,我们相信速度在bug面前不值一提。
那么为什么还是做了代码生成呢? 因为 “ 真香 ” 定律。
代码生成真的很香,但是依然建议在使用代码生成之前多去思考业务,三思之后再去使用它。
二、架构与思想
2.1、表结构
代码生成都离不开数据库的表结构的信息,所以表结构信息是要完善的,比如表的注释、列的注释等等
代码生成可能不止一次,所以代码生成的配置信息最好也能存储下来;
2.2 生成内容
对于中后台,大部分的功能都是类似的,无外乎“增删查改”,所以将需求拆分一下:
- 对于java的“增删查改”需要有如下信息:Controller、Service、Manager、Dao、Mapper、JavaBean(domain)
- 对于前端而言:列表:list.vue , 表单:form.vue,请求 api.js
三、具体使用
3.1、使用要求
表注释、表的每一列 必须有注释!!
3.2、使用方法
以超管
身份登录系统,打开代码生成
菜单页面
- 1)搜索 要生成的表信息
- 2)点击
代码配置
- 3)
![]() | ![]() |
在线代码配置 | 代码生成配置持久化 |
3.3 下载
点击列表中的 下载代码
即可 下载一个 代码压缩包了
3.4 代码在线预览
![]() |
四、实现原理
4.1、表设计
表t_code_generator_config
,将每一个步骤的信息都存下来。
![]() |
4.2、代码
具体代码在sa-base
项目的support.codegenerator
包
具体细节如下:
- 模板文件:
src/main/resource/code-generator-template/
- 模板技术: velocity
- 具体实现: 不难很简单 对于每一个模板文件,都有对应的
service
处理类,具体如下
![]() |