首页 > 编程语言 > 详细

Java IDEA 根据mybatis-generator-core自动生成代码(二)

时间:2020-07-20 01:00:19      阅读:83      评论:0      收藏:0      [点我收藏+]

    mybatis generator代码生成虽然好用,但是好像不支持sqlserver获取备注信息,这里我主要分享mybatis generator改写后支持sqlserver获取备注信息,mysql以及oracle数据库经过简单的配置再加以修改即可。针对sqlserver的命名规则,将字段NickName对应实体类的nickName,实现mysql以及sqlserver数据库共存情况下使用一个实体类。

    项目结构如下:

技术分享图片

 

 

 

1.这里主要需要添加的代码有:

引用的jar包

<dependencies>
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-data-jdbc</artifactId>
        </dependency>
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-web</artifactId>
        </dependency>

        <dependency>
            <groupId>org.projectlombok</groupId>
            <artifactId>lombok</artifactId>
            <optional>true</optional>
        </dependency>
        <dependency>
            <groupId>io.springfox</groupId>
            <artifactId>springfox-swagger2</artifactId>
            <version>${swagger.version}</version>
        </dependency>
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-test</artifactId>
            <scope>test</scope>
            <exclusions>
                <exclusion>
                    <groupId>org.junit.vintage</groupId>
                    <artifactId>junit-vintage-engine</artifactId>
                </exclusion>
            </exclusions>
        </dependency>

        <dependency>
            <groupId>com.alibaba</groupId>
            <artifactId>druid</artifactId>
            <version>1.1.21</version>
        </dependency>
        <!-- MySQL Connector -->
        <dependency>
            <groupId>mysql</groupId>
            <artifactId>mysql-connector-java</artifactId>
            <version>8.0.18</version>
            <scope>runtime</scope>
        </dependency>
        <!--jdbc启动器-->
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-jdbc</artifactId>
        </dependency>
        <dependency>
            <groupId>org.mybatis.spring.boot</groupId>
            <artifactId>mybatis-spring-boot-starter</artifactId>
            <version>1.3.2</version>
        </dependency>
        <dependency>
            <groupId>org.mybatis.generator</groupId>
            <artifactId>mybatis-generator-core</artifactId>
            <version>1.3.7</version>
        </dependency>
        <!-- https://mvnrepository.com/artifact/com.microsoft.sqlserver/mssql-jdbc -->
        <dependency>
            <groupId>com.microsoft.sqlserver</groupId>
            <artifactId>mssql-jdbc</artifactId>
            <version>8.3.1.jre8-preview</version>
        </dependency>
        <!-- https://mvnrepository.com/artifact/com.intellij/annotations -->
        <dependency>
            <groupId>com.intellij</groupId>
            <artifactId>annotations</artifactId>
            <version>12.0</version>
        </dependency>
    </dependencies>

 

 

sqlServerGeneratorConfig.xml

<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE generatorConfiguration PUBLIC
        "-//mybatis.org//DTD MyBatis Generator Configuration 1.0//EN"
        "http://mybatis.org/dtd/mybatis-generator-config_1_0.dtd">

<generatorConfiguration>
    <!-- 指定数据库驱动的jdbc驱动jar包的位置,这里需要写绝对位置 -->
    <classPathEntry location="D:\Java\myCodeMaven\maven-repository\com\microsoft\sqlserver\mssql-jdbc\8.3.1.jre8-preview\mssql-jdbc-8.3.1.jre8-preview.jar"/>
    <context id="mysql" defaultModelType="hierarchical" targetRuntime="MyBatis3Simple" >
        <!-- 生成的 Java 文件的编码 -->
        <property name="javaFileEncoding" value="UTF-8"/>
        <!-- 格式化 Java 代码 -->
        <property name="javaFormatter" value="org.mybatis.generator.api.dom.DefaultJavaFormatter"/>
        <!-- 格式化 XML 代码 -->
        <property name="xmlFormatter" value="org.mybatis.generator.api.dom.DefaultXmlFormatter"/>
        <!-- hasLombok -->
        <plugin type="org.mybatis.generator.plugins.LombokPlugin" >
            <property name="hasLombok" value="true"/>
        </plugin>
        <!--生成mapper.xml时覆盖原文件,防止追加-->
        <plugin type="org.mybatis.generator.plugins.UnmergeableXmlMappersPlugin" />
        <!-- 自定义注释生成器 -->
        <commentGenerator type="com.zsy.codegenerato.mbgcomment.MySQLCommentGenerator">
            <property name="author" value="zsy"/>
            <property name="dateFormat" value="yyyy/MM/dd"/>
            <property name="suppressDate" value="true"/>
            <property name="suppressAllComments" value="true"/>
        </commentGenerator>
        <!-- 配置数据库连接 -->
        <jdbcConnection driverClass="com.microsoft.sqlserver.jdbc.SQLServerDriver"
                        connectionURL="jdbc:sqlserver://127.0.0.1;DatabaseName=User"
                        userId="sa"
                        password="123456">
            <!-- Mysql数据库设置 useInformationSchema 属性为 true -->
            <property name="useInformationSchema" value="true" />
            <!-- 针对oracle数据库 -->
            <property name="remarksReporting" value="true"/>
            <!--设置可以获取remarks信息-->
            <property name="allProceduresAreCallable" value="true"/>
            <!--解决多个数据库表同名导致的问题,这个配置也很重要-->
            <property name="nullCatalogMeansCurrent" value="true"/>
        </jdbcConnection>
        <!-- 生成实体的位置 -->
        <javaModelGenerator targetPackage="com.zsy.codegenerato.models"
                            targetProject="code-generato/src/main/java">
            <property name="enableSubPackages" value="true"/>
        <!--以下配置将所有的实体类都继承至该基类-->
        <!--<property name="rootClass" value=""/>-->
        </javaModelGenerator>

        <!-- 生成 Mapper XML 的位置 -->
        <sqlMapGenerator targetPackage="mybatis.mapper"
                         targetProject="code-generato/src/main/resources">
            <property name="enableSubPackages" value="true"/>
        </sqlMapGenerator>

        <!-- 生成 Mapper 接口的位置 -->
        <javaClientGenerator type="XMLMAPPER"
                             targetPackage="com.zsy.codegenerato.mapper"
                             targetProject="code-generato/src/main/java">
            <property name="enableSubPackages" value="true"/>
<!--        <property name="rootInterface" value="java.io.Serializable"/>-->
        </javaClientGenerator>
        <!-- 设置数据库的表名和实体类名 -->
<!--        <table tableName="t_trade" domainObjectName="Trade"></table>-->
        <table tableName="UserInfo" domainObjectName="UserInfo"></table>
    </context>

</generatorConfiguration>
EmptyCommentGenerator.java
package com.zsy.codegenerato.mbgcomment;

import org.mybatis.generator.api.CommentGenerator;
import org.mybatis.generator.api.IntrospectedColumn;
import org.mybatis.generator.api.IntrospectedTable;
import org.mybatis.generator.api.dom.java.*;
import org.mybatis.generator.api.dom.xml.XmlElement;

import java.util.Properties;
import java.util.Set;

public class EmptyCommentGenerator implements CommentGenerator {

    @Override
    public void addConfigurationProperties(Properties properties) {

    }

    @Override
    public void addFieldComment(Field field, IntrospectedTable introspectedTable, IntrospectedColumn introspectedColumn) {

    }

    @Override
    public void addFieldComment(Field field, IntrospectedTable introspectedTable) {

    }

    @Override
    public void addModelClassComment(TopLevelClass topLevelClass, IntrospectedTable introspectedTable) {

    }

    @Override
    public void addClassComment(InnerClass innerClass, IntrospectedTable introspectedTable) {

    }

    @Override
    public void addClassComment(InnerClass innerClass, IntrospectedTable introspectedTable, boolean b) {

    }

    @Override
    public void addEnumComment(InnerEnum innerEnum, IntrospectedTable introspectedTable) {

    }

    @Override
    public void addGetterComment(Method method, IntrospectedTable introspectedTable, IntrospectedColumn introspectedColumn) {

    }

    @Override
    public void addSetterComment(Method method, IntrospectedTable introspectedTable, IntrospectedColumn introspectedColumn) {

    }

    @Override
    public void addGeneralMethodComment(Method method, IntrospectedTable introspectedTable) {

    }

    @Override
    public void addJavaFileComment(CompilationUnit compilationUnit) {

    }

    @Override
    public void addComment(XmlElement xmlElement) {

    }

    @Override
    public void addRootComment(XmlElement xmlElement) {

    }

    @Override
    public void addGeneralMethodAnnotation(Method method, IntrospectedTable introspectedTable, Set<FullyQualifiedJavaType> set) {

    }

    @Override
    public void addGeneralMethodAnnotation(Method method, IntrospectedTable introspectedTable, IntrospectedColumn introspectedColumn, Set<FullyQualifiedJavaType> set) {

    }

    @Override
    public void addFieldAnnotation(Field field, IntrospectedTable introspectedTable, Set<FullyQualifiedJavaType> set) {

    }

    @Override
    public void addFieldAnnotation(Field field, IntrospectedTable introspectedTable, IntrospectedColumn introspectedColumn, Set<FullyQualifiedJavaType> set) {

    }

    @Override
    public void addClassAnnotation(InnerClass innerClass, IntrospectedTable introspectedTable, Set<FullyQualifiedJavaType> set) {

    }
}
MySQLCommentGenerator.java
package com.zsy.codegenerato.mbgcomment;

import org.mybatis.generator.api.FullyQualifiedTable;
import org.mybatis.generator.api.IntrospectedColumn;
import org.mybatis.generator.api.IntrospectedTable;
import org.mybatis.generator.api.dom.java.*;
import org.mybatis.generator.api.dom.xml.Attribute;
import org.mybatis.generator.api.dom.xml.XmlElement;
import org.mybatis.generator.config.TableConfiguration;
import org.mybatis.generator.internal.db.ActualTableName;

import java.sql.Connection;
import java.sql.SQLException;
import java.text.SimpleDateFormat;
import java.util.*;

public class MySQLCommentGenerator extends EmptyCommentGenerator {

    private final Properties properties;
    private TopLevelClass topLevelClass;

    public MySQLCommentGenerator() {
        properties = new Properties();
    }

    @Override
    public void addConfigurationProperties(Properties properties) {
        // 获取自定义的 properties
        this.properties.putAll(properties);
    }

    @Override
    public void addModelClassComment(TopLevelClass topLevelClass, IntrospectedTable introspectedTable) {
        String author = properties.getProperty("author");
        String dateFormat = properties.getProperty("dateFormat", "yyyy-MM-dd");
        SimpleDateFormat dateFormatter = new SimpleDateFormat(dateFormat);

        //导入包
        //topLevelClass.addJavaDocLine("import javax.persistence.*;");
        topLevelClass.addJavaDocLine("import java.io.Serializable;");
        topLevelClass.addJavaDocLine("import io.swagger.annotations.*;");
        topLevelClass.addJavaDocLine("import lombok.*;");
        FullyQualifiedTable aa = introspectedTable.getFullyQualifiedTable();

        // 获取表注释
        String remarks = introspectedTable.getRemarks();
        topLevelClass.addJavaDocLine("");
        topLevelClass.addJavaDocLine("/**");
        topLevelClass.addJavaDocLine(" * @Description " + remarks);
        topLevelClass.addJavaDocLine(" * @Author      " + author);
        topLevelClass.addJavaDocLine(" * @Date        " + dateFormatter.format(new Date()));
        topLevelClass.addJavaDocLine(" */");
        topLevelClass.addJavaDocLine("@Data");
        topLevelClass.addJavaDocLine("@ApiModel(description= \""+remarks+"\")");

        //添加默认继承的接口(配置只有类继承类rootClass,接口继承接口rootInterface)
        topLevelClass.addSuperInterface(new FullyQualifiedJavaType("Serializable"));
    }

    @Override
    public void addFieldComment(Field field, IntrospectedTable introspectedTable, IntrospectedColumn introspectedColumn) {
        //获取列所处的位置
        List<IntrospectedColumn> allColumnList = introspectedTable.getAllColumns();
        int position = allColumnList.indexOf(introspectedColumn);
        if(position==0){
            field.addJavaDocLine("");
            field.addJavaDocLine(genSerialID());
        }
        field.addJavaDocLine("");
        // 获取列注释
        String remarks = introspectedColumn.getRemarks();
        field.addJavaDocLine("/**");
        field.addJavaDocLine(" * " + remarks);
        field.addJavaDocLine(" */");
        field.addJavaDocLine("@ApiModelProperty(value = \""+remarks+"\", position = "+position+")");
        //针对UserName 字段的处理,变成userName;userMessage还是userMessage
        //&& !Character.isLowerCase(columnName.charAt(0))
        String columnName = introspectedColumn.getActualColumnName();
        if(!columnName.contains("_") ){
            columnName =  (new StringBuilder()).append(Character.toLowerCase(columnName.charAt(0))).append(columnName.substring(1)).toString();
            field.setName(columnName);
        }
    }

    private static String genSerialID()
    {
        return "private static final long serialVersionUID =  "+Math.abs(new Random().nextLong())+"L;";
    }
}
LombokPlugin.java;这里是重点,去除了getter、setter,同时针对sqlserver数据库获取备注信息。
//这个包名保持这个
package org.mybatis.generator.plugins;

import org.mybatis.generator.api.ConnectionFactory;
import org.mybatis.generator.api.IntrospectedColumn;
import org.mybatis.generator.api.IntrospectedTable;
import org.mybatis.generator.api.PluginAdapter;
import org.mybatis.generator.api.dom.java.Field;
import org.mybatis.generator.api.dom.java.Method;
import org.mybatis.generator.api.dom.java.TopLevelClass;
import org.mybatis.generator.api.dom.xml.Attribute;
import org.mybatis.generator.api.dom.xml.Element;
import org.mybatis.generator.api.dom.xml.XmlElement;
import org.mybatis.generator.config.JDBCConnectionConfiguration;
import org.mybatis.generator.internal.JDBCConnectionFactory;
import org.mybatis.generator.internal.ObjectFactory;

import java.sql.Connection;
import java.sql.PreparedStatement;
import java.sql.ResultSet;
import java.sql.SQLException;
import java.text.SimpleDateFormat;
import java.util.Date;
import java.util.List;

/**
 * @author zsy 20200706
 */
public class LombokPlugin extends PluginAdapter {

    @Override
    public boolean validate(List<String> list) {
        return true;
    }

    @Override
    public boolean modelSetterMethodGenerated(Method method, TopLevelClass topLevelClass, IntrospectedColumn introspectedColumn, IntrospectedTable introspectedTable, ModelClassType modelClassType) {
        //不生成getter
        return false;
    }

    @Override
    public boolean modelGetterMethodGenerated(Method method, TopLevelClass topLevelClass, IntrospectedColumn introspectedColumn, IntrospectedTable introspectedTable, ModelClassType modelClassType) {
        //不生成setter
        return false;
    }

    @Override
    public boolean sqlMapResultMapWithoutBLOBsElementGenerated(XmlElement element, IntrospectedTable introspectedTable) {
        List<Element> elist = element.getElements();
        System.out.println("element.getName()="+element.getName());
        Integer elistCount = elist.size();
        for(Integer i=0;i<elistCount;i++){
            XmlElement xmlElement = (XmlElement)(elist.get(i));
            String columnName = "";
            List<Attribute> attributes = xmlElement.getAttributes();
            int  attributeCount = attributes.size();
            for(Integer j=0;j<attributeCount;j++){
                Attribute attribute = attributes.get(j);
                Attribute attributeNew=null;
                if(attribute.getName().equals("column")){
                    columnName = attribute.getValue();
                }else if(attribute.getName().equals("property")){
                    if(!"".equals(columnName) && attribute.getName().equals("property")){
                        // && !Character.isLowerCase(columnName.charAt(0))
                        if(!columnName.contains("_")){
                            attributeNew = new Attribute(attribute.getName(),
                                    (new StringBuilder()).append(Character.toLowerCase(columnName.charAt(0))).append(columnName.substring(1)).toString());
                            attributes.remove(attribute);
                            attributes.add(attributeNew);
                        }
                    }
                }
            }
        }
//        XmlElement xe = new XmlElement("result");
//        xe.addAttribute(new Attribute("column", "tablesite"));
//        xe.addAttribute(new Attribute("property", "tablesite"));
//        xe.addAttribute(new Attribute("jdbcType", "INTEGER"));
//        elist.add(xe);
        //return super.sqlMapResultMapWithoutBLOBsElementGenerated(element, introspectedTable);
        return true;
    }

    @Override
    public boolean sqlMapResultMapWithBLOBsElementGenerated(XmlElement element, IntrospectedTable introspectedTable) {
        //将首字母大写改为小写,后面的大小写不变(不存在"_"的时候)
        List<Element> elist = element.getElements();
        Integer elistCount = elist.size();
        for(Integer i=0;i<elistCount;i++){
            XmlElement xmlElement = (XmlElement)(elist.get(i));
            String columnName = "";
            List<Attribute> attributes = xmlElement.getAttributes();
            int  attributeCount = attributes.size();
            for(Integer j=0;j<attributeCount;j++){
                Attribute attribute = attributes.get(j);
                Attribute attributeNew=null;
                if(attribute.getName().equals("column")){
                    columnName = attribute.getValue();
                }else if(attribute.getName().equals("property")){
                    if(!"".equals(columnName) && attribute.getName().equals("property")){
                        // && !Character.isLowerCase(columnName.charAt(0))
                        if(!columnName.contains("_")){
                            attributeNew = new Attribute(attribute.getName(),
                                    (new StringBuilder()).append(Character.toLowerCase(columnName.charAt(0))).append(columnName.substring(1)).toString());
                            attributes.remove(attribute);
                            attributes.add(attributeNew);
                        }
                    }
                }
            }
        }
        return true;
        //return super.sqlMapResultMapWithoutBLOBsElementGenerated(element, introspectedTable);
    }

    @Override
    public void initialized(IntrospectedTable introspectedTable) {
        Connection connection = null;
        try {
            connection = getConnection();
            ResultSet sqlServerResultSet = null;
            ResultSet sqlServerTableResultSet = null;
            boolean isSqlServer = connection.getMetaData().getDriverName().toUpperCase()
                    .indexOf("SQL SERVER") != -1;
            if (isSqlServer) {
                //添加注释
                //sqljdbc与sqljdbc4不同,sqlserver中间有空格
                String sql = "SELECT\n" +
                        "\tconvert(varchar(1000), D.value) AS TABLEREMARKS,\n"+
                        "\tB.name AS COLUMNNAME,\n"+
                        "\tconvert(varchar(1000), C.\n" +
                        "VALUE)\n" +
                        "\tAS REMARKS\n" +
                        "FROM\n" +
                        "\tsys.tables A\n" +
                        "INNER JOIN sys.columns B ON B.object_id = A.object_id\n" +
                        "LEFT JOIN sys.extended_properties C ON C.major_id = B.object_id\n" +
                        "AND C.minor_id = B.column_id\n" +
                        "LEFT JOIN sys.extended_properties D ON D.major_id = A.object_id AND D.minor_id = 0\n"+
                        "WHERE\n" +
                        "\tA.name = ? ";
                PreparedStatement ps = connection.prepareStatement(sql);
                ps.setString(1, introspectedTable.getFullyQualifiedTable().getIntrospectedTableName());
                sqlServerResultSet = ps.executeQuery();
                if(sqlServerResultSet!=null){
                    List<IntrospectedColumn> allColumnList = introspectedTable.getAllColumns();
                    Integer index = 0;
                    int length = allColumnList.size();
                    while (sqlServerResultSet.next()){
                        if(index == 0){
                            introspectedTable.setRemarks(sqlServerResultSet.getString("TABLEREMARKS"));
                            index++;
                        }
                        for(Integer i=0;i<length;i++){
                            IntrospectedColumn columnInfo = allColumnList.get(i);
                            if(sqlServerResultSet.getString("COLUMNNAME").equals(columnInfo.getActualColumnName())){
                                allColumnList.get(i).setRemarks(sqlServerResultSet.getString("REMARKS"));
                            }
                        }
                    }
                }
            }
        } catch (SQLException e) {
            e.printStackTrace();
        }finally {
            closeConnection(connection);
        }
        introspectedTable.getAllColumns().forEach(m->{
            System.out.println(m.getActualColumnName()+"==="+m.getRemarks());
        });
    }

    private Connection getConnection() throws SQLException {
        Object connectionFactory;
        JDBCConnectionConfiguration jdbcConnectionConfiguration = context.getJdbcConnectionConfiguration();
        if (jdbcConnectionConfiguration != null) {
            connectionFactory = new JDBCConnectionFactory(jdbcConnectionConfiguration);
        } else {
            connectionFactory = ObjectFactory.createConnectionFactory(context);
        }

        return ((ConnectionFactory)connectionFactory).getConnection();
    }

    private void closeConnection(Connection connection) {
        if (connection != null) {
            try {
                connection.close();
            } catch (SQLException var3) {
            }
        }

    }
}
SqlServerGenerator.java
package com.zsy.codegenerato;

import org.mybatis.generator.api.MyBatisGenerator;
import org.mybatis.generator.config.Configuration;
import org.mybatis.generator.config.xml.ConfigurationParser;
import org.mybatis.generator.internal.DefaultShellCallback;

import java.io.File;
import java.util.ArrayList;
import java.util.List;

/**
 * 使用 Java 的方式来运行 MBG
 * @see <a href="http://www.mybatis.org/generator/running/runningWithJava.html">Running MyBatis Generator With Java</a>
 */
public class SqlServerGenerator {

    public static void main(String[] args) throws Exception {
        List<String> warnings = new ArrayList<>(2);
        ConfigurationParser cp = new ConfigurationParser(warnings);

        File configFile = new File("sqlServerGeneratorConfig.xml");
        Configuration config = cp.parseConfiguration(configFile);

        DefaultShellCallback callback = new DefaultShellCallback(true);

        MyBatisGenerator myBatisGenerator = new MyBatisGenerator(config, callback, warnings);
        myBatisGenerator.generate(null);
    }
}

2.将LombokPlugin.java文件生成的LombokPlugin.class放到本地仓库:D:\Java\myCodeMaven\maven-repository\org\mybatis\generator\mybatis-generator-core\1.3.7\mybatis-generator-core-1.3.7.jar\org\mybatis\generator\plugins下,需要用压缩文件打开mybatis-generator-core-1.3.7.jar,并将LombokPlugin.class文件复制到其中。

 技术分享图片

 

 

 技术分享图片

 

 技术分享图片

3.直接运行SqlServerGenerator.java即可。

Java IDEA 根据mybatis-generator-core自动生成代码(二)

原文:https://www.cnblogs.com/starrynightsky/p/13293394.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!