JAVA实现编写平台代码生成器
[项目中经常写CRUD,但实际这些工作,我觉得如果有一个完整的代码规范,完全可以自动生成,加快开发效率.
代码生成器技术原理不复杂,一般就是写好一个模板生成一系列的代码而已。我看到mybatis_plus的代码生成器就相当不错,就自己拿过来改造了一下
1.项目中,需先引入vm库,用来生成代码
<dependency>
<groupId>org.apache.velocity</groupId>
<artifactId>velocity</artifactId>
<version>${velocity.version}</version>
</dependency>
2.model的代码如下
/**
* <p>
* 考试题目表
* </p>
*
* @author starmark
* @since 2018-04-12
*/
@Data
@EqualsAndHashCode(callSuper=false)
public class Exam implements Serializable {
/**
* 主键
*/
@TableId("id")
private Long id;
/**
* 题目
*/
@TableField("subject")
private String subject;
/**
* 答案
*/
@TableField("answer")
private String answer;
/**
* 类别
*/
@TableField("category")
private String category;
@TableField("key_point")
private String keyPoint;
@TableField("created_by")
private String createdBy;
@TableField("created_date")
private Date createdDate;
@TableField("last_updated_by")
private String lastUpdatedBy;
@TableField("last_updated_date")
private Date lastUpdatedDate;
}
vm就改造成如下:
package ${package.Entity};
#if(${activeRecord})
import lombok.Data;
import lombok.EqualsAndHashCode;
#end
#foreach($pkg in ${table.importPackages})
import ${pkg};
#end
/**
* <p>
* ${table.comment}
* </p>
*
* @author ${author}
* @since ${date}
*/
${data}
${EqualsAndHashCode}
#if(${table.convert})
@TableName("${table.name}")
#end
#if(${superEntityClass})
public class ${entity} extends ${superEntityClass}#if(${activeRecord})<${entity}>#end {
#elseif(${activeRecord})
public class ${entity} implements Serializable {
#else
public class ${entity} implements Serializable {
#end
#foreach($field in ${table.fields})
#if(${field.keyFlag})
#set($keyPropertyName=${field.propertyName})
#end
#if("$!field.comment" != "")
/**
* ${field.comment}
*/
#end
#if(${field.convert})
#if(${field.keyFlag})
@TableId("${field.name}")
#else
@TableField("${field.name}")
#end
#end
private ${field.propertyType} ${field.propertyName};
#end
}
2.ServiceImpl实现类如下:
import com.starmark.exam.entity.Exam;
import com.starmark.exam.mapper.ExamMapper;
import com.starmark.exam.service.IExamService;
import com.starmark.core.base.AbstractBaseService;
import org.springframework.stereotype.Service;
import org.springframework.transaction.annotation.Transactional;
import org.springframework.transaction.annotation.Propagation;
/**
* <p>
* 考试题目表 服务实现类
* </p>
*
* @author starmark
* @since 2018-04-12
*/
@Service
@Transactional(propagation = Propagation.REQUIRED, rollbackFor = Exception.class)
public class ExamServiceImpl extends AbstractBaseService<ExamMapper, Exam> implements IExamService {
}
VM就写成如下:
package ${package.ServiceImpl};
import ${package.Entity}.${entity};
import ${package.Mapper}.${table.mapperName};
import ${package.Service}.${table.serviceName};
import ${superServiceImplClassPackage};
import org.springframework.stereotype.Service;
import org.springframework.transaction.annotation.Transactional;
import org.springframework.transaction.annotation.Propagation;
/**
* <p>
* ${table.comment} 服务实现类
* </p>
*
* @author ${author}
* @since ${date}
*/
@Service
@Transactional(propagation = Propagation.REQUIRED, rollbackFor = Exception.class)
public class ${table.serviceImplName} extends ${superServiceImplClass}<${table.mapperName}, ${entity}> implements ${table.serviceName} {
}
3.Controller实现类如下:
import io.swagger.annotations.ApiOperation;
import com.starmark.common.base.PageVo;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RestController;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.web.bind.annotation.RequestBody;
import org.springframework.web.bind.annotation.RequestMethod;
import org.springframework.web.bind.annotation.RequestParam;
import com.starmark.core.web.base.AbstractBaseController;
/**
* <p>
* 考试题目表 前端控制器
* </p>
*
* @author starmark
* @since 2018-04-12
*/
@RestController
@RequestMapping("/exam/exam")
public class ExamController extends AbstractBaseController<IExamService> {
@ApiOperation(value = "查询考试题目表列表")
@PutMapping(value = "/page")
public Object query(@RequestBody PageVo pageVo) {
return super.queryPage(pageVo);
}
@ApiOperation(value = "新增考试题目表")
@PostMapping
public Object add(@RequestBody SysOrgDept param) {
return super.add(param);
}
@ApiOperation(value = "考试题目表详情")
@GetMapping(value = "/{id}")
public Object get(@PathVariable("id") Long id) {
return super.get(id);
}
@PutMapping
@ApiOperation(value = "修改考试题目表")
public Object update(@RequestBody Exam param) {
return super.update(param);
}
@DeleteMapping(value = "/{id}")
@ApiOperation(value = "删除考试题目表")
public Object delete(@PathVariable("id") Long id) {
return super.delete(id);
}
}
VM就编写如下:
package ${package.Controller};
import io.swagger.annotations.ApiOperation;
import com.starmark.common.base.PageVo;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RestController;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.web.bind.annotation.RequestBody;
import org.springframework.web.bind.annotation.RequestMethod;
import org.springframework.web.bind.annotation.RequestParam;
#if(${superControllerClassPackage})
import ${superControllerClassPackage};
#end
/**
* <p>
* ${table.comment} 前端控制器
* </p>
*
* @author ${author}
* @since ${date}
*/
@RestController
@RequestMapping("#if(${package.ModuleName})/${package.ModuleName}#end/${table.entityPath}")
#if(${superControllerClass})
public class ${table.controllerName} extends ${superControllerClass}<${table.serviceName}> {
#else
public class ${table.controllerName} {
#end
@ApiOperation(value = "查询${table.comment}列表")
@PutMapping(value = "/page")
public Object query(@RequestBody PageVo pageVo) {
return super.queryPage(pageVo);
}
@ApiOperation(value = "新增${table.comment}")
@PostMapping
public Object add(@RequestBody SysOrgDept param) {
return super.add(param);
}
@ApiOperation(value = "${table.comment}详情")
@GetMapping(value = "/{id}")
public Object get(@PathVariable("id") Long id) {
return super.get(id);
}
@PutMapping
@ApiOperation(value = "修改${table.comment}")
public Object update(@RequestBody ${entity} param) {
return super.update(param);
}
@DeleteMapping(value = "/{id}")
@ApiOperation(value = "删除${table.comment}")
public Object delete(@PathVariable("id") Long id) {
return super.delete(id);
}
}
以上就是各个类之间对应的模板。
代码就是通过读数据库的表信息,含字段名称,注解难来生成相关的文件。
现在我项目开发是通过代码生成器生成代码,然后中途加字段是通过我另一文章
给mybatis添加自动建表,自动加字段的功能来加字段。
如果想要完整的代码生成器,请打赏一注彩票钱再联系我。

低调大师中文资讯倾力打造互联网数据资讯、行业资源、电子商务、移动互联网、网络营销平台。
持续更新报道IT业界、互联网、市场资讯、驱动更新,是最及时权威的产业资讯及硬件资讯报道平台。
转载内容版权归作者及来源网站所有,本站原创内容转载请注明来源。
-
上一篇
女生适合学习Java吗?
女生适合学习Java吗? 互联网行业成为了高薪的代名词,Java技术因其具有卓越的通用性、高效性、平台移植性和安全性,广泛应用于PC、数据中心、游戏控制台、科学超级计算机、移动电话和互联网,作为最流行的语言,学习的人也是越来越多。在很多人看来,学习java似乎是男生的专利,难道真的只有男生才能学好Java成为优秀的java工程师吗? “女生适合学Java吗?”“女程序员就业前景好不好?”“女生学Java会不会学不会啊?”等等这些问题是很多想学Java的女生经常纠结的。那为什么会有这样的问题呢?无非就是因为程序员队伍中,男生数量太大,或者觉得女生在逻辑思维上没有男生强,也可能是因为觉得女生承受不了经常加班的编程工作。这些担忧不无道理,但是只看到了女生不适合的一面,其实女生学Java也有男生所不能及的优势哦。就有很多的美女程序媛在这里奋斗着,当然,从成功走向职场的程序媛也是数不胜数的。 1、 无论男女,兴趣最重要 兴趣是最重要的老师,这一点我们不能否认,这与性别无关,对Java这个专业来说,兴趣尤其重要,不管男生还是女生,如果不敢兴趣,会觉得每天敲代码,单调无趣,以这种消极的状态学习当然是...
-
下一篇
java 读取excel文件转换成json格式
java 读取excel文件转换成json格式 需要读取excel数据转换成json数据,写了个测试功能,转换正常: JSON转换:org.json.jar 测试类: importFile.java: [java] view plain copy packagecom.siemens.util; importjava.util.ArrayList; importjava.util.List; importorg.json.JSONException; importorg.json.JSONObject; importorg.apache.poi.ss.usermodel.Row; importorg.apache.poi.ss.usermodel.Sheet; importorg.apache.poi.ss.usermodel.Workbook; //importcom.siemens.entity.master; //importcom.siemens.service.masterService; //importcom.siemens.serviceImpl.masterServi...
相关文章
文章评论
共有0条评论来说两句吧...
文章二维码
点击排行
推荐阅读
最新文章
- Linux系统CentOS6、CentOS7手动修改IP地址
- CentOS7编译安装Gcc9.2.0,解决mysql等软件编译问题
- CentOS7编译安装Cmake3.16.3,解决mysql等软件编译问题
- Jdk安装(Linux,MacOS,Windows),包含三大操作系统的最全安装
- 设置Eclipse缩进为4个空格,增强代码规范
- Docker容器配置,解决镜像无法拉取问题
- Docker快速安装Oracle11G,搭建oracle11g学习环境
- CentOS7设置SWAP分区,小内存服务器的救世主
- Dcoker安装(在线仓库),最新的服务器搭配容器使用
- MySQL数据库在高并发下的优化方案