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 ...
随机推荐
- vue 集成html5 plus
首先要安装一个包 vue-html5plus npm i vue-html5plus -S 然后配置这个文件 在main.js添加一串代码 var onPlusReady = function (ca ...
- Python Hacking Tools - Web Scraper
Preparation: Python Libray in the following programming: 1. Requests Document: https://2.python-requ ...
- .NET Core ResponseCache【缓存篇(一)】
一.前言 源码 1.最近一直在看项目性能优化方式,俗话说的好项目优化第一步那当然是添加缓存,我们的项目之所以卡的和鬼一样,要么就是你的代码循环查询数据库(这个之前在我们的项目中经常出现,现在慢慢在 ...
- Java常用开源库
Java的经久不衰,很大程度上得益于Java的生态好.在日常开发中,我们也会经常使用到各种开源库和工具类,为了避免重复造轮子,本文将贴出工作及学习中会用到的部分开源库和工具类.Java的生态实在太大, ...
- docker环境部署mysql
参考文档 docker官方:https://hub.docker.com/_/mysql/?tab=description 部署步骤 1. 拉取镜像 这里我拉取了tag为5.7的镜像 docker p ...
- 设计模式:command模式
目的:将命令设计成类的形式,并可以组织成队列 优点: 在需要的情况下,可以比较容易地将命令记入日志 可以容易的实现对请求的撤销和重做 由于新的具体命令类不影响其他的命令类,因此增加新的具体命令类很容易 ...
- python爬虫入门(5)----- 阿里巴巴供应商爬虫
阿里巴巴供应商爬虫# 起因## 学了爬虫入门之后,打算找一个有难度的网站来实践,一开始打算找淘宝或者天猫(业界老大)来实践,但后续发现网上已经有很多这方面的项目,于是瞄上了阿里的国际网站阿里巴巴.开始 ...
- web自动化 -- Keys(键盘操作)
Keys没啥好讲的 语法:Keys.CONTRAL 等等类似. 下方就是可以 Keys. 跟的键 那些 \ue000 就是对应的 Windows系统中的键盘码,pywin32 也一样的 ...
- js获取json对象的属性值
// var responseData = response.data.result; for (var r in responseData) { ...
- 21天学通PythonPDF高清完整版免费下载|百度云盘
百度云盘:21天学通PythonPDF高清完整版免费下载 提取码:nqa9 豆瓣评分: 书籍封面: 内容简介 · · · · · · <21天学通Python>全面.系统.深入地讲解了P ...