/SpringBootCodeGenerator

又名大狼狗代码生成器,基于SpringBoot2+Freemarker的JAVA代码生成器,以释放双手为目的,支持mysql/oracle/pgsql三大数据库, 用DDL-SQL语句生成JPA/JdbcTemplate/Mybatis/MybatisPlus/BeetlSQL等相关代码.

Primary LanguageJavaScriptMIT LicenseMIT

SpringBootCodeGenerator


又名JAVA在线代码生成平台sql转java大狼狗代码生成器mybatis在线生成器SQL转Java JPA、MYBATIS实现类代码生成平台
image image image Build Status

Author

powered by Moshow郑锴(大狼狗) , https://zhengkai.blog.csdn.net

Description

Based on SpringBoot2+Freemarker
#基于SpringBoot2Freemarker的代码生成平台

For reducing the repetitive CRUD work
#以解放双手为目的,减少大量的重复CRUD工作

mainly support mysql, support oracle and pgsql as well
#支持MySQL、Oracle、PgSQL三大主流数据库

generate to many popular templates by ddl-sql/insert-sql/simple json
可通过建表SQL语句INSERT语句或者简单JSON生成JPA/JdbcTemplate/Mybatis/MybatisPlus/BeetlSQL相关模板代码.

thanks for your using and feedback,I'm inspired by the 600PV every day and github more than 700 stars
感谢大家的使用和反馈,每天六百的PV和获得超过七百多的星星是我前进和继续做下去的动力。

hope everyone can keep good balance on work and life , stay health and safety , be smooth on work as well
愿大家可以维持生活和工作平衡,保持健康和安全,祝大家工作顺利!

Tips or Features

  • 支持DDL SQL/INSERT SQL/SIMPLE JSON三种生成模式
  • 自动记忆最近生成的内容,最多保留9个
  • 提供众多通用模板,易于使用,复制粘贴加简单修改即可完成CRUD操作
  • 支持特殊字符模板(#请用代替;$请用代替)
  • Util集合提供一些基本对象的使用方法供方便COPY,如对应的CRUD SQL语句、setMap、getMap、get属性等等
  • 关于类名注释,可根据comment=(mysql)或者comment on table(pgsql/oracle)生成
  • 可设置是否自动引包(java中的import)及引入包路径(java类中的package),建议取消并配合IDEA的自动引包更智能(Settings→Editor→General→Auto Import,勾选Add unambiguous imports on the fly以及Optimize imports on the fly)。
  • 可设置表名前缀,例如sys_user前缀为sys_之后可以正确生成user类
  • 可在applicaltion.yml中的OEM.mode设置js/css引入模式local(本地模式,默认)/CDN(云CDN模式,在线网站推荐,省流量)
  • OEM信息可以在applicaltion.yml中的OEM中更改

Url

感谢卡卡将他部署在BEJSON上,目前是besjon专供的金牌工具(线上版本不一定是最新的,会有延迟,请谅解,谢谢).

感谢三叔将他部署在DEVTOOLS上,继续作为Golden Tool开放给大家使用。

Thanks for JetBrains providing us the Licenses for Open Source DevelopmentGet free access to all JetBrains tools for developing your open source project! .

访问地址 http://localhost:1234/generator
BEJSON 在线地址 https://java.bejson.com/generator
DEVTOOLS 在线地址 https://java.devtools.cn
CSDN BLOG https://zhengkai.blog.csdn.net
GITEE仓库 https://gitee.com/moshowgame/SpringBootCodeGenerator/releases
GITHUB仓库 https://github.com/moshowgame/SpringBootCodeGenerator

Update Logs

更新日期 更新内容
2021.01.18 OEM信息优化,支持多配置文件模式,支持在application*.yml自定义信息,以及切换local/cdn模式。
2021.01.17 生成后自动trim掉前后空格输出。
完善ReadMe文档。
优化云CDN引入部分。
优化returnUtil部分。
表明前缀选项(感谢@wwlg的建议)。
是否带字段注释设置(感谢@fengpojian的建议)。
优化Mybatis的''!=判断(感谢@zhongsb的建议)。
Mybatis-Plus增加Service层(感谢@yf466532479的建议)。
2021.01.16 全新3.0版本:
一、前端半vue半js化,更多动态加载项。
二、支持更多生成设置,优化生成场景。
三、js导入支持本地/CDN模式,支持断网环境轻松使用。
2020.10.22 1.tinyint多加一个Short类型转换(感谢@wttHero的建议)
2020.10.20 1.修复mapper2 insert代码问题(感谢@mXiaoWan的PR)
2.优化对fulltext/index关键字的处理(感谢@WEGFan的反馈)。
3.新增日期类型的转换选择(感谢@qingkediguo的建议)。
4.新增是否包装类型的转换选择(感谢@gzlicanyi的建议)。
2020.06.28 优化Util下的BeanUtil,支持更多map.put的操作。整合CRUD模板到SQL(CRUD)模板。
2020.06.21 修复FreemarkerUtil的Path问题导致JAR包运行时无法获取template的问题。
2020.05.25 1.一些fix,关于封装工具类以及layui模板优化等.
2.优化表备注的获取逻辑.
3.生成时间格式改为yyyy-MM-dd,移除具体的时间,只保留日期
2020.05.22 1.新增insert-sql模式,支持对"insert into table (xxx) values (xxx)"语句进行处理,生成java代码(感谢三叔的建议).
2020.05.17 1.代码重构!异常处理优化,Freemarker相关工具类优化,简化模板生成部分,通过template.json来配置需要生成的模板,不需要配置java文件.
2.修复包含comment关键字时注释无法识别的问题.(感谢@1nchaos的反馈).
3.赞赏优化,感谢大家的赞赏.
4.新增mapper2(Mybatis-Annotation模板)(感谢@baisi525和@CHKEGit的建议).
2020.05.03 1.优化对特殊字符的处理,对于包含#和$等特殊字符的,在模板使用井和¥代替便可,escapeString方法会自动处理.
2.优化mybatisplus实体类相关(感谢@chunchengmeigui的反馈).
3.修优化对所有类型的判断(感谢@cnlw的反馈).
4.移除swagger-entity,该功能已经包含在‘swagger-ui’的下拉选项中
5.升级hutool和lombok版本
2020.03.06 1.提交一套layuimini+mybatisplus的模板.
2.修复mybatisplus一些相关问题.
2020.02.06 1.新增历史记录功能,自动保存最近生成的对象.
2.新增swagger开关选项和修复@Column带name参数(感谢@liuyu-struggle的建议).
3.去除mybatis模板中的方括号[]和修改模板里的类注释样式(感谢@gaohanghang的PR)
2019.12.29 1.修复bejson安全防护策略拦截问题(感谢@liangbintao和@1808083642的反馈).
2.优化字段名含date字符串的处理(感谢@smilexzh的反馈).
3.控制台动态输出项目访问地址(感谢@gaohanghang的提交)
2019.11.28 1.修复支持string-copy导致的以n结尾的字母不显示问题.
2.jpa-entity新增swagger@ApiModel@ApiModelProperty注解和SQL字段@Column注解(感谢@yjq907的建议)
2019.11.26 1.springboot2内置tomcat更换为性能更强大的undertow.
2.修复tinyintTransType参数丢失问题
2019.11.24 1.java代码结构优化.
2.新增简单的json生成模式.
3.新增简单的正则表达式匹配模式(感谢@ydq的贡献).
4.新增对复制String代码中的乱SQL代码的支持 5.优化对JSON的父子节点/处理,JSONObject和JSONArray节点处理,子节点缺失'{'头处理
2019.11.23 1.移除频繁出错和被过滤的layer,改为jquery-toast.
2.Util功能优化,新增json和xml.
2019.11.16 优化对primary关键字的处理(感谢@liujiansgit的反馈).
2019.11.15 1.添加tinyint类型转换(感谢@lixiliang&@liujiansgit的Suggestion).
2.添加一键复制功能(感谢@gaohanghang的Suggestion).
3.Mybatis的insert增加keyProperty="id"用于返回自增id(感谢@88888888888888888888的Suggestion).
4.优化date类型的支持(感谢@SteveLsf的反馈).
5.其他一些优化.
2019.10.15 修复jdbcTemplates中insert语句第一个字段丢失的问题.
2019.09.15 1.添加对象getset模板.
2.添加sql模板.
3.启动类添加日志输出,方便项目使用(感谢@gaohanghang 的pull request)
2019.09.10 优化以及更新Maven依赖,减少打包体积.
1.修复mapper接口load方法,但是xml中方法不匹配问题.
2.移除mapper中CRUD时的@param 注解,会影响xml的解析(感谢@caojiantao的反馈).
3.优化MyBatis的xml文件对Oracle的支持.(感谢@wylove1992的反馈).
4.新增对boolean的处理(感谢@violinxsc的反馈)以及优化tinyint类型生成boolean类型问题(感谢@hahaYhui的反馈)
2019.09.09 添加是否下划线转换为驼峰的选择(感谢@youngking28 的pull request).
2019.05.18 1.优化注释.
2.修改 mybatis模板中 controller注解.
3.修改 mybatis模板中 dao文件使用为 mapper文件.
4.修改 mybatis模板中 service实现类中的一个 bug.
5.修改 index.ftl文件中 mybatis模板的 dao -> mapper(感谢@unqin的pull request)
2019.05.11 优化mybatis模块的dao和xml模板,修改dao接口注解为@Repository,所有dao参数改为包装类,删除update语句最后的UpdateTime = NOW(),修改dao接口文件的方法注释使其更符合javaDoc的标准,修改insert语句增加插入行主键的返回,修改load的方法名为selectByPrimaryKey,修改xml的update语句新增动态if判空,修改xml的insert语句新增动态插入判空,更符合mybatisGenerator标准(感谢@Archer-Wen的贡献 ).
2019.04.29 新增返回封装工具类设置.
优化对oracle注释comment on column的支持(感谢@liukex反馈).
优化对普通和特殊storage关键字的判断(感谢@AhHeadFloating的反馈 ).
2019.02.11 提交gitignore,解决StringUtils.lowerCaseFirst潜在的NPE异常,校验修改为@RequestParam参数校验,lombok之@Data和@Slf4j优化,fix JdbcDAO模板类名显示为中文问题,WebMvcConfig整合MessageConverter,模板代码分类(感谢@liutf和@tfgzs的pull request).
2019.02.10 实体生成规则切换为包装类型,不再采用基本数据类型,为实体类生成添加显示的默认构造方法(感谢@h2so的pull request).
2019.01.06 修复处理number/decimal(x,x)类型的逻辑(感谢@arthaschan的反馈).
修复JdbcTemplates模板两处错误(感谢@everflourish的反馈).
2018.12.12 首页UI优化.
新增MybatisPlus模块(感谢@三叔同事的建议).
修复作者名和包名获取失败问题(感谢@Yanch1994的反馈).
2018.11.22 优化正则表达式点号的处理,优化处理字段类型,对number类型增加int,long,BigDecimal的区分判断(感谢@lshz0088的指导).
2018.11.08 修复非字段描述"KEY FK_xxxx (xxxx)"导致生成KEY字段情况(感谢@tornadoorz反馈).
2018.10.18 支持double(x,x)的类型,以及comment里面包含一些特殊字符的处理(感谢@tanwubo的反馈).
2018.10.10 CDN变更,修复CDN不稳定导致网页js报错问题.
2018.10.03 新增element-ui/bootstrap生成.
2018.10.02 修复公共CDN之Layer.js404问题,导致项目无法生成.
2018.09.27 优化COMMENT提取逻辑,支持多种复杂情况的注释(感谢@raodeming的反馈).
2018.09.26 全新BeetlSQL模块,以及一些小细节优化(感谢@三叔同事的建议).
2018.09.25 优化SQL表和字段备注的推断,包括pgsql/oralce的comment on column/table情况处理等.
2018.09.18 优化SQL类型推断.
优化PrimaryKey判断.
修复jpacontroller中Repository拼写错误问题.
2018.09.17 全新首页,静态文件全部采用CDN.新增jdbcTemplate模块.
2018.09.16 1.优化oracle支持,优化DDL语句中"或者'或者空格的支持.
2.补充char/clob/blob/json等类型,如果类型未知,默认为String.
2018.09.15 新增Swagger-UI模板.修复一些命名和导入问题.JPA的Entity默认第一个字段为Id,如果不是请手工修改.
2018.09.13 修复字段没有描述以及类型为DATE型导致的问题.新增JPA的Controller模板.
2018.08.31 初始化项目.新增JPA系列Entity+Repository模板.

ClassInfo/TableInfo

名称 说明
packageName 自定义的包名
authorName 自定义的作者名
tableName sql中的表名
className java类名
classComment sql表备注/java类备注
fieldName 字段名
fieldComment 字段备注

Options

名称 说明 默认值
作者 authorName zhengkai.blog.csdn.net
包名 packageName cn.devtools
返回(成功) returnUtilSuccess Return.SUCCESS
返回(失败) returnUtilFailure Return.ERROR
忽略前缀 ignorePrefix sys_
输入类型 dataType DDL SQL
TinyInt转换 tinyintTransType int
时间类型 timeTransType Date
命名类型 nameCaseType CamelCase/驼峰
是否包装类型 isPackageType true
是否swaggerUI isSwagger false
是否字段注释 isComment true
是否自动引包 isAutoImport
是否带包路径 isWithPackage
是否Lombok isLombok true

How to add a new template

  1. resources/templates/code-generator中找到对应类型
  2. COPY并编写freemarker模板文件.ftl
  3. 修改template.json文件,新增模板信息,页面可动态加载