《业务系统单表业务模块生成 》示例生成model类、xml映射文件、dao接口、service接口、serviceImpl接口、controller控制类、html页面、js文件。该示例结合教程,能够帮忙大家玩转mcg-helper研发小助手,为考虑到教程过长,分解成八节进行讲解,每节讲解一个代码文件的生成,因涉及从数据库读取表信息,大家启动mcg-helper后,切换到“工作台”,在“数据源”中将数据库信息修改,如图所示:
为保证与教程同步,请创建表,脚本如下:
CREATE TABLE `mcg_helper_user` (
`user_id` int(11) NOT NULL AUTO_INCREMENT COMMENT '自增主键',
`user_name` varchar(50) DEFAULT NULL COMMENT '用户名称',
`user_pwd` varchar(255) DEFAULT NULL COMMENT '用户密码',
PRIMARY KEY (`user_id`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8;
可以很清楚的看见,采用data控件、js脚本控件、文件控件完成了生成model类的工作。
data控件:读取数据库表,将表信息转换为映射对象数据,如表名、类名、包名、程序变量名、程序类型、表字段名、表字段类型、表字段长度等等;
js脚本控件:获取data控件的运行值,对数据进行转换和处理为生成model类需要的直接数据。
文件控件:编写freemaker模板语言,将js脚本控件的运行值作为参数,生成想要的model类代码,并保存到指定的文件中。
下面具体讲解如何运用这三个控件:
1、data控件的使用
双击data控件,在弹出层默认进入“关联表”选项卡,选择数据源、选择表后,将自动转换数据库表信息与对象的映射关系数据显示在表格中
切换到“属性”选项卡,编辑一些基本信息,之前选择表后,“类名”,“表名”会自动赋值
在流程执行中,data控件运行值如下:
{
"userData":{
"record":[
{
"autoincrement":true,
"classField":"userId",
"comment":"自增主键",
"dataType":"Integer",
"include":"java.lang.Integer",
"length":10,
"mandatory":true,
"precision":0,
"primary":true,
"show":false,
"tableField":"user_id",
"tableFieldType":"INT"
},
{
"autoincrement":false,
"classField":"userName",
"comment":"用户名称",
"dataType":"String",
"include":"java.lang.String",
"length":50,
"mandatory":false,
"precision":0,
"primary":false,
"show":false,
"tableField":"user_name",
"tableFieldType":"VARCHAR"
},
{
"autoincrement":false,
"classField":"userPwd",
"comment":"用户密码",
"dataType":"String",
"include":"java.lang.String",
"length":255,
"mandatory":false,
"precision":0,
"primary":false,
"show":false,
"tableField":"user_pwd",
"tableFieldType":"VARCHAR"
}
],
"property":{
"className":"McgHelperUser",
"dataDesc":"用户管理",
"key":"userData",
"name":"读取用户表信息",
"packageName":"com.mcghelper.model",
"tableName":"mcg_helper_user"
}
}
}
双击js脚本控件,编辑框中默认进入“属性”选项卡,可编辑控件名称、控件Key、说明信息
切换到“源代码”选项卡,该控件需要编写原生javascript,主要作用把所有父级的运行值处理为文本控件生成所需要的值,这里只有一个data控件为父级,运行值可以参数上面,编写的代码如下图:
在流程执行时,运行值如下:
{
"modelScript":{
"userData":{
"record":[
{
"include":"java.lang.Integer",
"tableField":"user_id",
"dataType":"Integer",
"precision":0,
"length":10,
"show":false,
"mandatory":true,
"classFieldMethod":"UserId",
"classField":"userId",
"tableFieldType":"INT",
"autoincrement":true,
"comment":"自增主键",
"primary":true
},
{
"include":"java.lang.String",
"tableField":"user_name",
"dataType":"String",
"precision":0,
"length":50,
"show":false,
"mandatory":false,
"classFieldMethod":"UserName",
"classField":"userName",
"tableFieldType":"VARCHAR",
"autoincrement":false,
"comment":"用户名称",
"primary":false
},
{
"include":"java.lang.String",
"tableField":"user_pwd",
"dataType":"String",
"precision":0,
"length":255,
"show":false,
"mandatory":false,
"classFieldMethod":"UserPwd",
"classField":"userPwd",
"tableFieldType":"VARCHAR",
"autoincrement":false,
"comment":"用户密码",
"primary":false
}
],
"property":{
"dataDesc":"用户管理",
"name":"读取用户表信息",
"className":"McgHelperUser",
"packageName":"com.mcghelper.model",
"key":"userData",
"tableName":"mcg_helper_user"
}
},
"xmlFileName":"McgHelperUser.xml",
"modelFileName":"McgHelperUser.java"
}
}
3、文件控件的使用
双击文本控件,编辑框默认进入“属性”选项卡,获取为所有父级控件的运行值作为参数,这里父级只有JS脚本控件,参考上图,其中${modelScript.modelFileName }的值应该为“McgHelperUser.java”
切换到“源代码”选项卡,文本控件通过编写freemaker模板语言来生成想要的代码,将所有父级的运行值作为参数
生成结果如下:
package com.mcghelper.model;
public class McgHelperUser {
public McgHelperUser() {
}
/* 自增主键 */
private Integer userId;
/* 用户名称 */
private String userName;
/* 用户密码 */
private String userPwd;
public Integer getUserId() {
return this.userId;
}
public String getUserName() {
return this.userName;
}
public String getUserPwd() {
return this.userPwd;
}
public void setUserId(Integer userId) {
this.userId = userId;
}
public void setUserName(String userName) {
this.userName = userName;
}
public void setUserPwd(String userPwd) {
this.userPwd = userPwd;
}
}
到此,我们本节教程讲解完毕,在实际中,结合控件台输出的日志可以很好的调试,以上的运行值也是从控制台中截取的,在mcg-helper控制台不仅输出各控件的参数、运行值等,而且可以自定义输出某个变量的值,这样有助力在有逻辑性的地方可以输出值定位排查问题。
mcg-helper的使用指南:http://blog.csdn.net/loginandpwd/article/details/76944900
mcg-helper研发小助手发布v1.0.0-beta版本:http://blog.csdn.net/loginandpwd/article/details/77447363
mcg-helper研发小助手软件介绍:http://blog.csdn.net/loginandpwd/article/details/77751566
生成model类:http://blog.csdn.net/loginandpwd/article/details/77448277
生成xml映射文件:http://blog.csdn.net/loginandpwd/article/details/77452902
生成dao接口:http://blog.csdn.net/loginandpwd/article/details/77452927
生成service接口:http://blog.csdn.net/loginandpwd/article/details/77452946
生成serviceImpl实现类:http://blog.csdn.net/loginandpwd/article/details/77452979
生成controller控制类:http://blog.csdn.net/loginandpwd/article/details/77452993
生成html页面:http://blog.csdn.net/loginandpwd/article/details/77453013
生成js文件:http://blog.csdn.net/loginandpwd/article/details/77453024