前些天在做我的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)代码生成器扩展的更多相关文章

  1. Spring boot + mybatis + mysql代码生成器

    引入依赖: 在pom文件最下边: <build> <plugins> <!--逆向工程--> <plugin> <groupId>org.m ...

  2. SpringMVC+Spring+Mybatis+Mysql项目搭建

    眼下俺在搭建一个自己的个人站点玩玩.一边练习.一边把用到的技术总结一下,日后好复习. 站点框架大致例如以下图所看到的: 眼下仅仅用到了SpringMVC+Spring+Mybatis+Mysql.把它 ...

  3. 0120 springboot集成Mybatis和代码生成器

    在日常开发中,数据持久技术使用的架子使用频率最高的有3个,即spring-jdbc , spring-jpa, spring-mybatis.详情可以看我之前的一篇文章spring操作数据库的3个架子 ...

  4. PHP安装mysql.so扩展

    在PHP中mysql_connect模块已经逐渐被弃用,我在搭建环境时也没有再安装mysql扩展,但是今天在维护一个老项目时,出现报错 Fatal error: Uncaught Error: Cal ...

  5. 解决springmvc+mybatis+mysql中文乱码问题【转】

    这篇文章主要介绍了解决java中springmvc+mybatis+mysql中文乱码问题的相关资料,需要的朋友可以参考下 近日使用ajax请求springmvc后台查询mysql数据库,页面显示中文 ...

  6. Mybatis + Mysql 插入数据时中文乱码问题

    近日跟朋友一起建立一个项目,用的是spring+mybatis+mysql. 今天碰到一个mybatis向mysql中插入数据时,中文显示为'???'的问题,拿出来说下. 对于数据库操作中出现的中文乱 ...

  7. 使用spring boot+mybatis+mysql 构建RESTful Service

    开发目标 开发两个RESTful Service Method Url Description GET /article/findAll POST /article/insert 主要使用到的技术 j ...

  8. Spirng+SpringMVC+Maven+Mybatis+MySQL项目搭建(转)

    这篇文章主要讲解使用eclipse对Spirng+SpringMVC+Maven+Mybatis+MySQL项目搭建过程,包括里面步骤和里面的配置文件如何配置等等都会详细说明. 如果还没有搭建好环境( ...

  9. freemarker + spring mvc + spring + mybatis + mysql + maven项目搭建

    今天说说搭建项目,使用freemarker + spring mvc + spring + mybatis + mysql + maven搭建web项目. 先假设您已经配置好eclipse的maven ...

随机推荐

  1. 前端06 /JavaScript之BOM、DOM

    前端06 /JavaScript 目录 前端06 /JavaScript 昨日内容回顾 js的引入 js的编程要求 变量 输入输出 基础数据类型 number string boolean null ...

  2. 关于PowerShell调用Linq的一组实验

    Windows PowerShell 版权所有 (C) Microsoft Corporation.保留所有权利. 尝试新的跨平台 PowerShell https://aka.ms/pscore6 ...

  3. bzoj3767A+B Problem加强版

    bzoj3767A+B Problem加强版 题意: 求两个数的和,每个数绝对值≤10^(10^7). 题解: 又用Python水过了…… 代码: a=raw_input() b=a.split() ...

  4. UnsupportedClassVersionError的错误处理

    造成这种错误的原因是支持Tomcat运行的JDK版本与支持application运行的JDK版本不一致导致的. 解决办法: 将JDK版本改成一致. 步骤 1.Window ——> Prefere ...

  5. [C++面向对象]-C++成员函数和非成员函数

    大纲: 1.成员函数和非成员函数 2.详细解释 3.总结 4.参考   1.成员函数和非成员函数   其实简单来说成员函数是在类中定义的函数,而非成员函数就是普通函数,即不在类中定义的函数,其中非成员 ...

  6. [Qt2D绘图]-03坐标系统之坐标变换

    大纲:     基本变换         介绍和常用API     窗口-视口转换         窗口         视口         让窗口和视口维持相同宽高比来防止变形   基本变换 默认 ...

  7. Pytorch实现基于卷积神经网络的面部表情识别(详细步骤)

    文章目录 一.项目背景 二.数据处理 1.标签与特征分离 2.数据可视化 3.训练集和测试集 三.模型搭建 四.模型训练 五.完整代码 一.项目背景数据集cnn_train.csv包含人类面部表情的图 ...

  8. OKex平台如何使用谷歌身份验证?

    打开OK交易所官网,找到谷歌身份验证器的开启界面 登陆后点击右上角头像-账户和安全 然后[安全设置]里出现“谷歌验证”的位置,点击开启按钮,到了二维码和密钥显示的界面 我们不使用谷歌身份验证器,因为需 ...

  9. Monster Audio 使用教程 (八) Vst3 使用侧链功能

    Monster Audio对 Vst3 插件支持侧链功能,例如,我们插入一个Waves C1 comp Stereo 效果器 然后在侧链处,就可以选择任意一个音轨的信号,作为侧链信号源. 注意,只有v ...

  10. 如何在Windows、Linux系统中安装Redis

    一:Windos下安装Redis并设置自动启动 1.下载windows版本的Redis 去官网找了很久,发现原来在官网上可以下载的windows版本的,现在官网已经没有windows版本的下载地址,只 ...