美文网首页Java
六、Mybatis Generator

六、Mybatis Generator

作者: Jiangyouhua | 来源:发表于2021-10-31 13:48 被阅读0次

    Hi,大家好,我是姜友华。
    这一次,我们一起来实现,从数据库生成实体类和Mapper。

    Mybatis Generator,是我们今天所需要用到的工具。关于Mybatis Generator的作用,可进入官网里看看。

    一、添加mybatis generator。

    1. 在pom.xml里添加mybatis generator支持。
      官方配置及说明里,将Maven 部分复制过来即可。
    ......
               <plugin>
                    <groupId>org.mybatis.generator</groupId>
                    <artifactId>mybatis-generator-maven-plugin</artifactId>
                    <version>1.4.0</version>   
                    <configuration>
                        <verbose>true</verbose>
                        <overwrite>true</overwrite>
                    </configuration>
                </plugin>
    ......
    
    • <configuration>可以不添加。<overwrite>值为true时,每次生成都会覆盖原生成的文件。
    1. 下载mysql-connector-java-8.0.27.jar官网可选择平台下载,没有macOS,下载Linux的一样,解压后回得到mysql-connector-java-8.0.27.jar。注意存储位置,下面的配置文件里需要用到。
    2. src/main/resources/添加`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>
    
        <!-- 使用已有的配置文件 -->
        <properties resource="application.properties"></properties>
        <!-- 数据库驱动 -->
        <classPathEntry location="/Users/jiangyouhua/soft/mysql-connector-java-8.0.27.jar"/>
    
        <context id="DB2Tables" targetRuntime="MyBatis3">
            <!-- 数据库连接 -->
            <jdbcConnection driverClass="${spring.datasource.driver-class-name}"
                            connectionURL="${spring.datasource.url}"
                            userId="${spring.datasource.username}"
                            password="${spring.datasource.password}">
            </jdbcConnection>
    
            <!-- 非必须,类型处理器,在数据库类型和java类型之间的转换控制 -->
            <javaTypeResolver >
                <property name="forceBigDecimals" value="false" />
            </javaTypeResolver>
    
            <!-- Entity Java Class -->
            <javaModelGenerator targetPackage="com.muutr.shop.entity" targetProject="./src/main/java">
                <property name="enableSubPackages" value="false" />
                <property name="trimStrings" value="true" />
            </javaModelGenerator>
    
            <!-- Mapper Java Class -->
            <sqlMapGenerator targetPackage="mapper"  targetProject="./src/main/resources">
                <property name="enableSubPackages" value="false" />
            </sqlMapGenerator>
    
            <!-- Mapper XML File -->
            <javaClientGenerator type="XMLMAPPER" targetPackage="com.muutr.shop.mapper"  targetProject="./src/main/java">
                <property name="enableSubPackages" value="false" />
            </javaClientGenerator>
    
            <!-- 需要生成的数据库表 -->
            <table schema="shop" tableName="user_info" domainObjectName="UserInfo" enableCountByExample="false" enableDeleteByExample="false"
                   enableSelectByExample="false" enableUpdateByExample="false">
            </table>
    
        </context>
    </generatorConfiguration>
    
    • 连接数据库的配置,我们使用application.properties;
    • 数据库驱动,使用我们刚刚下载的mysql-connector-java-8.0.27.jar;
    • enableSubPackages值为false,表示不使用子包;
    • <table>里关闭所有示例。
    1. 运行一下。
      在Maven标签里,找到Plugins/mybatis-generator/mybatis-generator.generate,双击运行后生成Entity、Mapper、Mapper.xml文件。 双击运行

    二、结合Lombok。

    现在生成的UserInfo,有一堆SetterGetter。在前面,我们使用过Lombok的,现在需要将它融入进来。我们使用已有的轮子MyBatis Generator Lombok plugin

    1. 修改pom.xml
      是放在generator插件标签里。
    ......
                <plugin>
                    <groupId>org.mybatis.generator</groupId>
                    <artifactId>mybatis-generator-maven-plugin</artifactId>
                    <version>1.4.0</version>
                    <configuration>
                        <verbose>true</verbose>
                        <overwrite>true</overwrite>
                    </configuration>
                    <dependencies>
                        <dependency>
                            <groupId>com.softwareloop</groupId>
                            <artifactId>mybatis-generator-lombok-plugin</artifactId>
                            <version>1.0</version>
                        </dependency>
                    </dependencies>
                </plugin>
    ......
    
    1. 修改fgeneratorConfig
      是放在<context>里。
    ......
            <plugin type="com.softwareloop.mybatis.generator.plugins.LombokPlugin">
                <!-- enable annotations -->
                <property name="builder" value="true"/>
                <!-- annotation's option(boolean) -->
                <property name="builder.fluent" value="true"/>
                <!-- annotation's option(String) -->
                <property name="builder.builderMethodName" value="myBuilder"/>
                <property name="accessors" value="true"/>
                <!-- annotation's option(array of String) -->
                <property name="accessors.prefix" value="m_, _"/>
                <!-- disable annotations -->
                <property name="allArgsConstructor" value="false"/>
            </plugin>
    ......
    
    • 再运行Maven Plugins,生成的UserInfo是没有SetterGetter
      好,今天就这些。我是姜友华,下次见。

    相关文章

      网友评论

        本文标题:六、Mybatis Generator

        本文链接:https://www.haomeiwen.com/subject/pduoaltx.html