wGenerator代码生成工具
由来
以前一直用window系列的操作系统,有不少可以用的代码生成工具,如:动软的代码生成器(.net),可以自定义模板,然后按需生成代码。后来用mac系统,发现好像没有什么太好用的生成工具,所以自己写个吧!!!
我始终认为,工具就是工具,还没有达到可以替代人脑编程的地步,工具只是一个加速器,还是需要自己修剪枝蔓,才能打造好的代码!
这就是wGenerator的由来!!之所以叫wGenerator,是取了我姓的首字母。
http://wgenerator.51dmai.com
特点
小巧灵活——您可以随心所欲的编写模板,模板语法简单,然后去生成!
随心而为——完全根据项目与个人喜好,自由发挥!
解放时间——不必再手工敲一些固有的代码,如:entity之类的,节省下来的时间,去理清逻辑重点,哪怕是抽个时间画个手稿流程图,也会让你思路清晰,变成省力!
缺点
无法做到一键生成解决方案,还需要去建文件,copy代码,修饰代码,工具能给你的就是加快了速度,规范了格式!
数据库支持
| 序号 | 名称 | 支持 |
|---|---|---|
| 1 | mysql | Y |
| 2 | db2 | Y |
| 3 | sqlserver | Y |
| 4 | oracle | Y |
| 5 | sqlite | Y |
| 6 | postgreSql | Y |
如何使用
只需要3步,没错就是3步。
Copy一个建表语句
选择一个模板
点击生成,就可以copy代码了
模板示例
以Java中的entity实体类来做展示:
//$!table.comment
public class $!table.className implements Serializable{
#foreach($!tc in $!columns)
private $!tc.dlType $!tc.dlEntity; //$!tc.comment
#end
#foreach($!tc in $!columns)
public void set$!tc.dlMethod ($!tc.dlType $!tc.dlEntity){
this.$!tc.dlEntity = $!tc.dlEntity;
}
public $!tc.dlType get$!tc.dlMethod (){
return this.$!tc.dlEntity;
}
#end
}
生成后的代码
//参数配置
public class AdConfig implements Serializable{
private String code; //配置编号
private String name; //配置名称
private String value; //值
private String remark; //说明
public void setCode (String code){
this.code = code;
}
public String getCode (){
return this.code;
}
public void setName (String name){
this.name = name;
}
public String getName (){
return this.name;
}
public void setValue (String value){
this.value = value;
}
public String getValue (){
return this.value;
}
public void setRemark (String remark){
this.remark = remark;
}
public String getRemark (){
return this.remark;
}
}
模板中的公有参数说明
| 序号 | 参数 | 名称 | velocity中调用 |
|---|---|---|---|
| 1 | table | 表(对象)点击查看 | $!{table.tableName} |
| 2 | columns | 列(列表)点击查看 | #foreach($!tc in $!columns) $!tc.dlType #end |
| 3 | now | 时间(字符串)格式:yyyy-MM-dd HH:mm:ss | $!{now} |
| 4 | author | 开发者(字符串) | $!{author} |
| 5 | dbName | 数据库名(字符串) | $!{dbName} |
table 对象包含字段说明
| 序号 | 字段 | 类型 | 说明 |
|---|---|---|---|
| 1 | tableName | String | 表名称 |
| 2 | autoIncrement | Integer | 是否自增 |
| 3 | tableCollation | String | 字符顺序 |
| 4 | comment | String | 备注 |
| 5 | className | String | 对应的类名称 规范:首字母大写,如果表名师 aaa_bbb_cc 格式,将会被对应为: AaaBbbCc |
| 6 | classEntity | String | 对应的类实体 规范:首字母小写,把className组成的值,首字母小写,来对应实例化操作 根据上面的例子,应为: aaaBbbCc |
| 7 | columns | List | 列集合;在单个代码生成时,这个没有值 |
column 对象包含字段说明
| 序号 | 字段 | 类型 | 说明 |
|---|---|---|---|
| 1 | tableName | String | 表名 |
| 2 | name | String | 列名 |
| 3 | position | Integer | 顺序位置 |
| 4 | columnDefault | String | 默认值 |
| 5 | isNull | String | 是否为空 |
| 6 | comment | String | 备注 |
| 7 | dataType | String | 数据类型 |
| 8 | columnType | String | 字段类型 |
| 9 | key | String | 主键,外键,索引等 |
| 10 | extra | String | 扩展:是否自增 |
| 11 | dlType | String | 动态语言中的类型 |
| 12 | dlEntity | String | 动态语言中的实体 |
| 13 | dlMethod | String | 动态语言中的set.get方法跟的 |
| 14 | control | String | 特殊字段的表单控件名: checkbox,select,radio |
| 15 | dicts | List | 特殊字段的备选值:key,value访问 用于生成的时候自动生成对应的控件 点击查看如何定义 |
| 16 | jdbcType | String | mybatis中可能会用到 |
如何自己写模板
特殊字段规范
##请在数据库建表的时候,备注一栏按此格式去编写,将会被识别
##[P1]=[字段的说明,如:行状态]
##[P2]=[表单控件,支持: checkbox,select,radio]
##[P3]=[备选值:kv模式,末尾的;不能去掉]
[字段说明123][checkbox][k1=v1;k2=v2;k3=v3;]
VTL语法说明
//工具投射过来的变量访问
//访问变量采用 $!{var} $!var 的格式 ,建议采用带{}的访问方式
$!{table.tableName} //页面上会输出 ad_config
//设置一个变量
#set($var1="123")
//输出一个变量
$!{var1} //将会输出 123
//vtl中的注释写法
#**这中间的文字是被注释的哦,适用于多行注释**#
##我也备注是了,不会被输出,适用于单行注释
//如何循环
//默认的循环次数的引用变量名为$velocityCount
#foreach($!tc in $!columns)
//循环里给变量设置值
#set($var1=$var1+","+$tc.dlEntity)
#if("PRI"=="$!tc.key")
#set($firstColumn = $!{tc.name.toLowerCase()} )
#end
//输出字段的备注
$!{tc.comment}
#end
//如何判定
#if(""=="$!var1")
直接输出我把
#elseif("123"=="$!var1")
输出123
#else
我不知道了
#end
VTL保留字输出替代方案
如果在编写模板的时候,需要输出vtl的保留字,请将变量定义为以下格式,程序将会自动转换
暂时支持这3个,后期发现再加:
[#] => #
[$] => $
[!] => !
视频教程
注册

为了节省您的时间,简化填写步骤。您只需要扫描下方二维码就可以完成注册了。
wGenerator代码生成工具的更多相关文章
- Map工具系列-01-Map代码生成工具说明
所有cs端工具集成了一个工具面板 -打开(IE) Map工具系列-01-Map代码生成工具说明 Map工具系列-02-数据迁移工具使用说明 Map工具系列-03-代码生成BySQl工具使用说明 Map ...
- mybatis实战教程(mybatis in action)之九:mybatis 代码生成工具的使用
mybatis 应用程序,需要大量的配置文件,对于一个成百上千的数据库表来说,完全手工配置,这是一个很恐怖的工作量. 所以mybatis 官方也推出了一个mybatis代码生成工具的jar包. 今天花 ...
- 第二章 Mybatis代码生成工具
1.mybatis-generator作用 1).生成pojo 与 数据库结构对应 2).如果有主键,能匹配主键 3).如果没有主键,可以用其他字段去匹配 4).动态select,update,del ...
- 【C#】Excel做的数据表、SQLParameter代码生成工具
转载请注明出处http://www.cnblogs.com/Vulpers/ 做了一个小的代码生成工具,用于新建数据表时能够快速生成一些重复性很高的代码,目前仅支持SqlServer数据库及C#语言, ...
- 代码生成工具Database2Sharp中增加视图的代码生成以及主从表界面生成功能
在代码生成工具的各种功能规划中,我们一向以客户的需求作为驱动,因此也会根据需要增加一些特殊的功能或者处理.在实际的开发中,虽然我们一般以具体的表进行具体业务开发,但是有些客户提出有时候视图开发也是很常 ...
- Web API应用架构在Winform混合框架中的应用(4)--利用代码生成工具快速开发整套应用
前面几篇介绍了Web API的基础信息,以及如何基于混合框架的方式在WInform界面里面整合了Web API的接入方式,虽然我们看似调用过程比较复杂,但是基于整个框架的支持和考虑,我们提供了代码生成 ...
- RUF MVC5 Repositories Framework Generator代码生成工具介绍和使用
RUF MVC5 Repositories Framework Generator代码生成工具介绍和使用 功能介绍 这个项目经过了大半年的持续更新到目前的阶段基本稳定 所有源代码都是开源的,在gith ...
- 利用代码生成工具Database2Sharp设计数据编辑界面
在Winform程序开发中,界面部分的开发工作量一般是比较大的,特别是表的字段数据比较多的情况下,数据编辑界面所需要的繁琐设计和后台逻辑处理工作量更是直线上升,而且稍不注意,可能很多处理有重复或者错误 ...
- 配置VS代码生成工具ReSharper快捷键
VS代码生成工具ReSharper提供了丰富的快捷键,可以极大地提高你的开发效率.安装ReSharper后首次启动Visual Studio时,会出现一个名为ReSharper Keyboard Sc ...
随机推荐
- CSS 静态进度条效果
今天学习到了实现一个静态进度条的方法,固写一篇笔记稳固一下自己的知识. 最终的效果如下,进度条放在一个框里,水平宽自适应. 现在就开始,首先写一个进度条先. .progress-bar{ /* 进度条 ...
- 在高分屏正确显示CHM文件
今天下了白色相簿2推,发现里面的chm格式的帮助文档显示不正确,又没法在应用程序直接设置系统分辨率托管,google了一下找到了这个方法: 新建 HKEY_LOCAL_MACHINE\ SOFTWAR ...
- nfs 、ftp 和samba都有什么区别?
NFS:Network File System 是已故的Sun公司制定的用于分布式访问的文件系统,它的本质是文件系统.主要在Unix系列操作系统上使用,基于TCP/IP协议层,可以将远程的计算机磁盘挂 ...
- React入门一
React.js算是当今主流框架之一了,好多公司项目都是React.直接上图: 所以最近整合一些论坛,今儿咱就说说React, React 是一个用于构建用户界面的 JAVASCRIPT 库. Rea ...
- NS3系列——eclipse + NS3环境搭建
1. 安装NS3 (1)在 ubuntu12.04 中安装 ns3.20,首先要安装一下各种依赖软件: sudo apt-get install gcc g++ pythonsudo apt-get ...
- System.nanoTime理解
JDK1.5之后java中的计时给出了更精确的方法:System.nanoTime(),输出的精度是纳秒级别,这个给一些性能测试提供了更准确的参考. 但是这个方法有个需要注意的地方,不能用来计算今天是 ...
- Oracle-12:伪列rowid和rownum
------------吾亦无他,唯手熟尔,谦卑若愚,好学若饥------------- 伪列:不真实存储在真表中,但是我们可以查询到不能对伪列进行增删改操作! 分页可以用rownum来分!!!!!! ...
- 集成学习之Boosting —— AdaBoost原理
集成学习大致可分为两大类:Bagging和Boosting.Bagging一般使用强学习器,其个体学习器之间不存在强依赖关系,容易并行.Boosting则使用弱分类器,其个体学习器之间存在强依赖关系, ...
- Can I use MyBatis to generate Dynamic SQL without executing it?
Although MyBatis was designed to execute the query after it builds it, you can make use of it's conf ...
- HSLA色相饱和透明度
H:Hue(色调),取值为:0 - 360.将色相值想成一个圆环中的度数,随着在圆环上移动,得到不同的颜色. S:Saturation(饱和度),取值为:0.0% - 100.0%.数值越低(降低饱和 ...