mybatis逆向工程,自动生成带中文注释方法,根据mysql中的表生成bean,*mapper.java,*mapper.xml文件

参考:

https://blog.csdn.net/formydream111/article/details/85712742

2种方式:

第一种: 从命令提示符 使用 XML 配置文件  

 使用场景:对逆向工程定制较少,项目工程结构比较复杂的情况

   java -jar mybatis-generator-core-x.x.x.jar -configfile generatorConfig.xml    

打开cmd,切换到在当前目录下:输入以下命令,就可以了

java -Dfile.encoding=UTF-8 -jar mybatis-generator-core-1.3.5.jar -configfile generatorConfig.xml -overwrite

 使用场景:对逆向工程定制较少,项目工程结构比较复杂的情况

generatorConfig.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>


    <!-- 加载数据库驱动 -->
    <classPathEntry location="mysql-connector-java-5.1.18.jar" />
    
    <!-- context:生成一组对象的环境 
            id:必选,上下文id,用于在生成错误时提示 
            defaultModelType:指定生成对象的样式 
                 1,conditional:类似hierarchical;
                 2,flat:所有内容(主键,blob)等全部生成在一个对象中,推荐使用; 
                   3,hierarchical:主键生成一个XXKey对象(key class),Blob等单独生成一个对象,其他简单属性在一个对象中(record class) 
              targetRuntime: 
                   1,MyBatis3:默认的值,生成基于MyBatis3.x以上版本的内容,包括XXXBySample; 
                 2,MyBatis3Simple:类似MyBatis3,只是不生成XXXBySample; 
     -->
    <context id="context1" targetRuntime="MyBatis3"    defaultModelType="flat">
    
        <!-- 生成的Java文件的编码 -->
        <property name="javaFileEncoding" value="UTF-8"/>
    
    
        <commentGenerator>
            <!-- 是否去除自动生成的注释 true:是 : false:否 -->
            <property name="suppressAllComments" value="false" />
            <!-- 阻止注释中包含时间戳 true:是 : false:否 -->
            <property name="suppressDate" value="true" />
            <!--  注释是否包含数据库表的注释信息  true:是 : false:否 -->
            <property name="addRemarkComments" value="true" />
        </commentGenerator>
        <!--数据库连接的信息:驱动类、连接地址、用户名、密码 -->
        <jdbcConnection driverClass="com.mysql.jdbc.Driver"
            connectionURL="jdbc:mysql://localhost:3306/mybatis" userId="root" password="123456" />

 

        <!--类型处理器,在数据库类型和java类型之间的转换控制-->
        <javaTypeResolver >
            <property name="forceBigDecimals" value="false" />
        </javaTypeResolver>


        <!-- java模型创建器,是必须要的元素   负责:1,key类(见context的defaultModelType);2,java类;3,查询类
            targetPackage:生成的类要放的包,真实的包受enableSubPackages属性控制;
            targetProject:目标项目,指定一个存在的目录下,生成的内容会放到指定目录中,如果目录不存在,MBG不会自动建目录
         -->
        <javaModelGenerator targetPackage="com.enjoylearning.mybatis.entity" targetProject="src/main/java">
            <!-- 设置一个根对象,
                          如果设置了这个根对象,那么生成的keyClass或者recordClass会继承这个类;在Table的rootClass属性中可以覆盖该选项
                          注意:如果在key class或者record class中有root class相同的属性,MBG就不会重新生成这些属性了,包括:
                    1,属性名相同,类型相同,有相同的getter/setter方法;
             -->
            <property name="rootClass" value="com.enjoylearning.mybatis.entity.BaseEntity" />
        </javaModelGenerator>


        <!-- 生成SQL map的XML文件生成器,
            targetPackage:生成的类要放的包,真实的包受enableSubPackages属性控制;
            targetProject:目标项目,指定一个存在的目录下,生成的内容会放到指定目录中,如果目录不存在,MBG不会自动建目录
         -->
        <sqlMapGenerator targetPackage="." targetProject="src/main/resources/sqlmapper">
        </sqlMapGenerator>
        
        
         <!-- 对于mybatis来说,即生成Mapper接口,注意,如果没有配置该元素,那么默认不会生成Mapper接口 
                type:选择怎么生成mapper接口(在MyBatis3/MyBatis3Simple下):
                    1,ANNOTATEDMAPPER:会生成使用Mapper接口+Annotation的方式创建(SQL生成在annotation中),不会生成对应的XML;
                    2,MIXEDMAPPER:使用混合配置,会生成Mapper接口,并适当添加合适的Annotation,但是XML会生成在XML中;
                    3,XMLMAPPER:会生成Mapper接口,接口完全依赖XML;
                注意,如果context是MyBatis3Simple:只支持ANNOTATEDMAPPER和XMLMAPPER
            -->        
        <javaClientGenerator targetPackage="com.enjoylearning.mybatis.mapper"    targetProject="src/main/java" type="XMLMAPPER" />


        <!-- shema 数据库 tableName表明 -->
        <table schema="mybatis" tableName="t_user"   enableCountByExample="false"
            enableUpdateByExample="false" enableDeleteByExample="false"
            enableSelectByExample="false" selectByExampleQueryId="false">
            <generatedKey column="id" sqlStatement="MySql"/>
        </table>

    <table schema="mybatis" tableName="t_user_test"   enableCountByExample="false"
            enableUpdateByExample="false" enableDeleteByExample="false"
            enableSelectByExample="false" selectByExampleQueryId="false">
            <generatedKey column="id" sqlStatement="MySql"/>
        </table>

    </context>
</generatorConfiguration>

 


第二种:

使用场景:对逆向工程定制较多,项目工程结构比较单一的情况

 mvn mybatis-generator:generate 从另一个 Java 程序 使用 XML 配置文件

在Intellij IDEA添加一个“Run运行”选项,使用maven运行mybatis-generator-maven-plugin插件:



<?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>
    <!--数据库驱动-->
    <classPathEntry    location="E:\tools\jars\mysql-connector-java-5.1.18.jar"/>
    <context id="context"    targetRuntime="MyBatis3">
        <commentGenerator>
            <property name="suppressDate" value="true"/>
            <property name="suppressAllComments" value="false"/>
        </commentGenerator>
        <!--数据库链接地址账号密码-->
        <jdbcConnection driverClass="com.mysql.jdbc.Driver" connectionURL="jdbc:mysql://49.*.*.*:30001/mof*_i?serverTimezone=UTC" userId="local_test" password="YwjLoca***82">
<!--        <jdbcConnection driverClass="com.mysql.jdbc.Driver" connectionURL="jdbc:mysql://49.*.*.*:30001/e*j_**serverTimezone=UTC" userId="local_test" password="YwjLoca**82">-->
        </jdbcConnection>
        
        <!--类型处理器,在数据库类型和java类型之间的转换控制-->
        <javaTypeResolver >
            <property name="forceBigDecimals" value="false" />
        </javaTypeResolver>

        <!--生成Model(实体)类存放位置 -->
        <javaModelGenerator targetPackage="com.abao.bean" targetProject="src/main/java">
            <property name="enableSubPackages" value="true"/>
            <property name="trimStrings" value="true"/>
        </javaModelGenerator>
        <!--生成映射文件(xml文件)存放位置-->
        <sqlMapGenerator targetPackage="mapper" targetProject="src/main/resources">
            <property name="enableSubPackages" value="true"/>
        </sqlMapGenerator>
        <!--生成Dao类存放位置-->
        <javaClientGenerator type="XMLMAPPER" targetPackage="com.abao.dao" targetProject="src/main/java">
            <property name="enableSubPackages" value="true"/>
        </javaClientGenerator>
        <!--生成对应表及类名-->
        <table tableName="business_connection"  enableCountByExample="false" enableUpdateByExample="false" enableDeleteByExample="false" enableSelectByExample="false" selectByExampleQueryId="false">
            <generatedKey column="id" sqlStatement="MySql"/>
        </table>
<!--        <table tableName="user_password" domainObjectName="userpasswordDAO" enableCountByExample="false" enableUpdateByExample="false" enableDeleteByExample="false" enableSelectByExample="false" selectByExampleQueryId="false"></table>-->
    </context>
</generatorConfiguration>


点击运行就可以了

 



mybatis-generator 自动生成带中文注释方法

mybatis-generator-core-1.3.2.jar

下载地址 在我的资源里:https://download.csdn.net/download/sunboychenll/12898332

 

不知道在哪里找到这个jar(这个jar包在你的maven仓库里),覆盖这个jar即可,下面是我的项目示意图:

我的pom文件引用:

 <plugin>
        <groupId>org.mybatis.generator</groupId>
        <artifactId>mybatis-generator-maven-plugin</artifactId>
        <version>1.3.2</version>
        <configuration>
          <configurationFile>${basedir}/src/main/resources/generator/generatorConfig.xml</configurationFile>
          <overwrite>true</overwrite>
          <verbose>true</verbose>
        </configuration>
      </plugin>

运行之后结果如下

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值