mybatis(mysql)代码生成器扩展
前些天在做我的KSF框架的时候需要用到mybatis代码生成器,
但是发现有一些东西需要调整,主要集中在以下几点:
1. 加入batchInsert
2. 加入batchUpdate
3. mysql字段名和关键字冲突问题
4. 生成的实体类继承基类
5. mapper继承基础接口,实现自己的代码
6. insert之后获取生成的ID
7. 使实体可序列化
加入batchInsert
1.在generatorConfig.xml中加入以下插件
<plugin type="com.itfsw.mybatis.generator.plugins.BatchInsertPlugin"/>
2.在pom的mybatis-generator-maven-plugin中加入以下依赖
<dependency>
<groupId>com.itfsw</groupId>
<artifactId>mybatis-generator-plugin</artifactId>
<version>1.0.5</version>
</dependency>
加入batchUpdate
1.在generatorConfig.xml中加入以下插件
<plugin type="com.kuta.base.mybatis.plugins.KutaBatchUpdatePlugin"/>
2.编写插件代码
package com.kuta.base.mybatis.plugins; import java.util.List; import org.mybatis.generator.api.IntrospectedColumn;
import org.mybatis.generator.api.IntrospectedTable;
import org.mybatis.generator.api.dom.java.FullyQualifiedJavaType;
import org.mybatis.generator.api.dom.java.Interface;
import org.mybatis.generator.api.dom.java.TopLevelClass;
import org.mybatis.generator.api.dom.xml.Document;
import org.mybatis.generator.api.dom.xml.TextElement;
import org.mybatis.generator.api.dom.xml.XmlElement;
import org.mybatis.generator.codegen.mybatis3.MyBatis3FormattingUtilities;
import org.mybatis.generator.config.MergeConstants; import com.kuta.base.database.util.SqlMapperGeneratorTool; public class KutaBatchUpdatePlugin extends org.mybatis.generator.api.PluginAdapter{ private final static String BATCH_UPDATE = "batchUpdate"; private final static String PARAMETER_NAME = "recordList"; @Override
public boolean validate(List<String> list) {
return true;
} @Override
public boolean clientGenerated(Interface interfaze, TopLevelClass topLevelClass, IntrospectedTable introspectedTable) { if (introspectedTable.getTargetRuntime().equals(IntrospectedTable.TargetRuntime.MYBATIS3)) {
MethodGeneratorTool.defaultBatchInsertOrUpdateMethodGen(MethodGeneratorTool.UPDATE, interfaze, introspectedTable, context);
}
return super.clientGenerated(interfaze, topLevelClass, introspectedTable);
} @Override
public boolean sqlMapDocumentGenerated(Document document, IntrospectedTable introspectedTable) {
if (introspectedTable.getTargetRuntime().equals(IntrospectedTable.TargetRuntime.MYBATIS3)) {
addSqlMapper(document, introspectedTable);
}
return super.sqlMapDocumentGenerated(document, introspectedTable);
} public void addSqlMapper(Document document, IntrospectedTable introspectedTable) {
String tableName = introspectedTable.getFullyQualifiedTableNameAtRuntime();
List<IntrospectedColumn> columnList = introspectedTable.getAllColumns();
//primaryKey的JDBC名字
String primaryKeyName = introspectedTable.getPrimaryKeyColumns().get(0).getActualColumnName(); //primaryKey的JAVA变量
String primaryKeyParameterClause = MyBatis3FormattingUtilities.getParameterClause(introspectedTable.getPrimaryKeyColumns().get(0), "item."); //primaryKey的JAVA名字
String primaryKeyJavaName = introspectedTable.getPrimaryKeyColumns().get(0).getJavaProperty(); XmlElement updateXmlElement = SqlMapperGeneratorTool.baseElementGenerator(SqlMapperGeneratorTool.UPDATE,
BATCH_UPDATE,
FullyQualifiedJavaType.getNewListInstance());
updateXmlElement.addElement(new TextElement("<!-- generated by Kuta batchUpdate plugin - "
+ MergeConstants.NEW_ELEMENT_TAG + " -->"));
updateXmlElement.addElement(new TextElement(String.format("update %s ", tableName))); XmlElement trimElement = SqlMapperGeneratorTool.baseTrimElement("set", null, ","); for (int i = 0; i < columnList.size(); i++) { IntrospectedColumn introspectedColumn = columnList.get(i); String columnName = introspectedColumn.getActualColumnName(); String columnJavaTypeName = introspectedColumn.getJavaProperty("item."); String parameterClause = MyBatis3FormattingUtilities.getParameterClause(introspectedColumn, "item."); if (introspectedColumn.isIdentity()) {
continue;
} String ifSql = String.format("when %s then %s", primaryKeyParameterClause, parameterClause);
XmlElement ifElement = SqlMapperGeneratorTool.baseIfJudgeElementGen(columnJavaTypeName, ifSql, false); String ifNullSql = String.format("when %s then %s", primaryKeyParameterClause, tableName + "." + columnName);
XmlElement ifNullElement = SqlMapperGeneratorTool.baseIfJudgeElementGen(columnJavaTypeName, ifNullSql, true); XmlElement foreachElement = SqlMapperGeneratorTool.baseForeachElementGenerator(PARAMETER_NAME, "item", "index", null);
foreachElement.addElement(ifElement);
foreachElement.addElement(ifNullElement); XmlElement caseTrimElement = SqlMapperGeneratorTool.baseTrimElement(columnName + " =case " + primaryKeyName, "end,", null);
caseTrimElement.addElement(foreachElement); trimElement.addElement(caseTrimElement);
} updateXmlElement.addElement(trimElement); XmlElement foreachElement = SqlMapperGeneratorTool.baseForeachElementGenerator(PARAMETER_NAME,
"item",
"index",
",");
foreachElement.addElement(new TextElement(primaryKeyParameterClause)); updateXmlElement.addElement(new TextElement(String.format("where %s in(", primaryKeyName))); updateXmlElement.addElement(foreachElement); updateXmlElement.addElement(new TextElement(")")); document.getRootElement().addElement(updateXmlElement);
} }
package com.kuta.base.mybatis.plugins; import java.util.Set;
import java.util.TreeSet; import org.mybatis.generator.api.CommentGenerator;
import org.mybatis.generator.api.IntrospectedTable;
import org.mybatis.generator.api.dom.java.FullyQualifiedJavaType;
import org.mybatis.generator.api.dom.java.Interface;
import org.mybatis.generator.api.dom.java.JavaVisibility;
import org.mybatis.generator.api.dom.java.Method;
import org.mybatis.generator.api.dom.java.Parameter;
import org.mybatis.generator.config.Context; public class MethodGeneratorTool {
private final static String BATCH_INSERT = "batchInsert"; private final static String PARAMETER_NAME = "recordList"; private final static String DELETE_PARAMETER_NAME = "ids"; private final static String BATCH_UPDATE = "batchUpdate"; private final static String BATCH_DELETE = "batchDelete"; public final static Integer INSERT = 0; public final static Integer UPDATE = 1;
/**
* java方法生成构造器.
*
* @param methodName the method name
* @param visibility the visibility
* @param returnJavaType the return java type
* @param parameters the parameters
* @author HuWeihui
* @since hui_project v1
*/
public static Method methodGenerator(String methodName,
JavaVisibility visibility,
FullyQualifiedJavaType returnJavaType,
Parameter... parameters) {
Method method = new Method();
method.setName(methodName);
method.setVisibility(visibility);
method.setReturnType(returnJavaType);
for (Parameter parameter : parameters) {
method.addParameter(parameter);
}
return method;
} /**
* 导入基础的java类型
*
* @param introspectedTable the introspected table
* @return the set
* @author HuWeihui
* @since hui_project v1
*/
public static Set<FullyQualifiedJavaType> importedBaseTypesGenerator(IntrospectedTable introspectedTable){
//获取实体类类型
FullyQualifiedJavaType parameterType = introspectedTable.getRules().calculateAllFieldsClass();
//@Param需要导入的类型
FullyQualifiedJavaType paramType = new FullyQualifiedJavaType("org.apache.ibatis.annotations.Param");
//Integer类型
FullyQualifiedJavaType intInstance = FullyQualifiedJavaType.getIntInstance();
//List<Entity>
FullyQualifiedJavaType listParameterType = FullyQualifiedJavaType.getNewListInstance(); Set<FullyQualifiedJavaType> importedTypes = new TreeSet<FullyQualifiedJavaType>();
importedTypes.add(parameterType);
importedTypes.add(intInstance);
importedTypes.add(paramType);
importedTypes.add(listParameterType);
return importedTypes;
} /**
* 默认的批量新增/更新方法构造器.
*
* @param interfaze the interfaze
* @param introspectedTable the introspected table
* @param context the context
* @author HuWeihui
* @since hui_project v1
*/
public static void defaultBatchInsertOrUpdateMethodGen(Integer type ,Interface interfaze,IntrospectedTable introspectedTable, Context context){
//JAVA导入基础包
Set<FullyQualifiedJavaType> importedTypes = MethodGeneratorTool.importedBaseTypesGenerator(introspectedTable); //List<Entity>
FullyQualifiedJavaType listParameterType = FullyQualifiedJavaType.getNewListInstance();
listParameterType.addTypeArgument(introspectedTable.getRules().calculateAllFieldsClass()); String methodName = BATCH_INSERT;
//1.batchInsert
if (type.equals(UPDATE)){
methodName = BATCH_UPDATE;
}
Method insertMethod = MethodGeneratorTool.methodGenerator(methodName,
JavaVisibility.DEFAULT,
FullyQualifiedJavaType.getIntInstance(),
new Parameter(listParameterType, PARAMETER_NAME, "@Param(\"" + PARAMETER_NAME + "\")")); CommentGenerator commentGenerator = context.getCommentGenerator();
commentGenerator.addGeneralMethodComment(insertMethod, introspectedTable); interfaze.addImportedTypes(importedTypes);
interfaze.addMethod(insertMethod);
} /**
* 默认的批量删除方法构造器.
*
* @param interfaze the interfaze
* @param introspectedTable the introspected table
* @param context the context
* @author HuWeihui
* @since hui_project v1
*/
public static void defaultBatchDeleteMethodGen(Interface interfaze,IntrospectedTable introspectedTable, Context context){
//JAVA导入基础包
Set<FullyQualifiedJavaType> importedTypes = MethodGeneratorTool.importedBaseTypesGenerator(introspectedTable);
FullyQualifiedJavaType paramType = introspectedTable.getPrimaryKeyColumns().get(0).getFullyQualifiedJavaType();
Method batchDeleteMethod = MethodGeneratorTool.methodGenerator(BATCH_DELETE,
JavaVisibility.DEFAULT,
FullyQualifiedJavaType.getIntInstance(),
new Parameter(new FullyQualifiedJavaType(paramType.getFullyQualifiedName()+"[]"), DELETE_PARAMETER_NAME, "@Param(\""+DELETE_PARAMETER_NAME+"\")")); context.getCommentGenerator().addGeneralMethodComment(batchDeleteMethod,introspectedTable);
interfaze.addImportedTypes(importedTypes);
interfaze.addMethod(batchDeleteMethod);
}
}
3. 在pom的mybatis-generator-maven-plugin中加入以上代码所在库的依赖
mysql字段名和关键字冲突问题
1.在generatorConfig.xml中加入以下属性配置
<property name="beginningDelimiter" value="`"></property >
<property name="endingDelimiter" value="`"></property >
2. 在table节点加入delimitAllColumns="true"属性
生成的实体类继承基类
在generatorConfig.xml文件中的javaModelGenerator节点中加入以下属性配置
<property name="rootClass" value="com.kuta.base.database.entity.KutaDBEntity"/>
mapper继承基础接口,实现自己的代码
在generatorConfig.xml文件中的table节点加入以下属性配置
<property name="rootInterface" value="com.simcity.database.dao.extend.BuildMapperBase"/>
insert之后获取生成的ID
在generatorConfig.xml文件中的table节点加入以下属性配置
<generatedKey column="bid" sqlStatement="MySql" identity="true"/>
使实体可序列化
在generatorConfig.xml文件中加入以下属性配置
<plugin type="org.mybatis.generator.plugins.SerializablePlugin" />
mybatis(mysql)代码生成器扩展的更多相关文章
- Spring boot + mybatis + mysql代码生成器
引入依赖: 在pom文件最下边: <build> <plugins> <!--逆向工程--> <plugin> <groupId>org.m ...
- SpringMVC+Spring+Mybatis+Mysql项目搭建
眼下俺在搭建一个自己的个人站点玩玩.一边练习.一边把用到的技术总结一下,日后好复习. 站点框架大致例如以下图所看到的: 眼下仅仅用到了SpringMVC+Spring+Mybatis+Mysql.把它 ...
- 0120 springboot集成Mybatis和代码生成器
在日常开发中,数据持久技术使用的架子使用频率最高的有3个,即spring-jdbc , spring-jpa, spring-mybatis.详情可以看我之前的一篇文章spring操作数据库的3个架子 ...
- PHP安装mysql.so扩展
在PHP中mysql_connect模块已经逐渐被弃用,我在搭建环境时也没有再安装mysql扩展,但是今天在维护一个老项目时,出现报错 Fatal error: Uncaught Error: Cal ...
- 解决springmvc+mybatis+mysql中文乱码问题【转】
这篇文章主要介绍了解决java中springmvc+mybatis+mysql中文乱码问题的相关资料,需要的朋友可以参考下 近日使用ajax请求springmvc后台查询mysql数据库,页面显示中文 ...
- Mybatis + Mysql 插入数据时中文乱码问题
近日跟朋友一起建立一个项目,用的是spring+mybatis+mysql. 今天碰到一个mybatis向mysql中插入数据时,中文显示为'???'的问题,拿出来说下. 对于数据库操作中出现的中文乱 ...
- 使用spring boot+mybatis+mysql 构建RESTful Service
开发目标 开发两个RESTful Service Method Url Description GET /article/findAll POST /article/insert 主要使用到的技术 j ...
- Spirng+SpringMVC+Maven+Mybatis+MySQL项目搭建(转)
这篇文章主要讲解使用eclipse对Spirng+SpringMVC+Maven+Mybatis+MySQL项目搭建过程,包括里面步骤和里面的配置文件如何配置等等都会详细说明. 如果还没有搭建好环境( ...
- freemarker + spring mvc + spring + mybatis + mysql + maven项目搭建
今天说说搭建项目,使用freemarker + spring mvc + spring + mybatis + mysql + maven搭建web项目. 先假设您已经配置好eclipse的maven ...
随机推荐
- [Qt插件]-01Qt插件&&提升部件(自定义控件)
本篇的文档为:How to Create Qt Plugins https://doc.qt.io/qt-5/plugins-howto.html 前言 Qt插件(Qt Plugin)就是一个共享 ...
- 通过代理模块拦截网页应用程序流量 - Intercept Web Application Traffic Using Proxy Modules
测试网站: http://testphp.vulnweb.com/login.php 浏览器代理设置为:127.0.0.1:8080 查看拦截流量: 方式1:通Proxy - Intercept 方式 ...
- Python Hacking Tools - Port Scanner
Socket Programming 1. Scan the target Vulnerable Server. And test it by telnet. 2. Write the scanne ...
- Inoreader - 在线Rss阅读器
- springboot(九)文件上传
在企业级项目开发过程中,上传文件是最常用到的功能.SpringBoot集成了SpringMVC,当然上传文件的方式跟SpringMVC没有什么出入.下面我们来创建一个SpringBoot项目完成单个. ...
- MySQL(四)数据备份与还原
数据备份与还原: 备份:将当前已有的数据或者记录保留 还原:将已经保留的数据恢复到对应的表中 为什么要做备份还原: 1.防止数据丢失:被盗.误操作 2.保护数据的记录 数据备份还原的方式很多:数据表备 ...
- 重学c#系列——非托管实例(五)
前言 托管资源到是好,有垃圾回收资源可以帮忙,即使需要我们的一些小小的调试来优化,也是让人感到欣慰的.但是非托管资源就显得苍白无力了,需要程序员自己去设计回收,同样有设计的地方也就能体现出程序员的设计 ...
- 谁来教我渗透测试——VMware工具安装和使用
今天我们继续渗透测试学习系列了,昨天我们看了基础概念,今天我们来学习一下渗透测试必备的功能VMware安装. 首先我们下载好VMware workstation Pro的安装包.可以在百度上直接百度下 ...
- Spring+hibernate+JSP实现Piano的数据库操作---3.Piano实体类
package com.entity; import org.springframework.stereotype.Component; import javax.persistence.*; @Co ...
- 两数相加(B站看视频总结)
''' 两数相加: 给出两个 非空 的链表用来表示两个非负的整数 各自的位数是按照逆序的方式存储的 每一个节点只能保存 一位数 示例: 输入:(2->4->3) + (5->6-&g ...