zoukankan      html  css  js  c++  java
  • Eclipse中使用Mybatis Generator自动生成POJO类、mapper类等

    一、首先去Eclipse Marketplace 中安装插件Mybatis Generator,如果安装了,如下图所示,我已经安装过了。

    二、pom.xml文件除了正常的依赖,增加mybatis-generator-core的依赖(我使用的是1.3.2版本)

    <dependency>
      <groupId>org.mybatis.generator</groupId>
      <artifactId>mybatis-generator-core</artifactId>
       <version>1.3.2</version>
    </dependency>

    三、增加一个编译插件

    <plugin>
      <groupId>org.mybatis.generator</groupId>
      <artifactId>mybatis-generator-maven-plugin</artifactId>
      <version>1.3.2</version>
      <configuration>
        <verbose>true</verbose>
        <overwrite>true</overwrite>
      </configuration>
    </plugin>    

    四、完整的pom.xml配置如下:

    <project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
        xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/maven-v4_0_0.xsd">
        <modelVersion>4.0.0</modelVersion>
        <groupId>cn.com.winson.springboot</groupId>
        <artifactId>maven-springboot</artifactId>
        <packaging>war</packaging>
        <version>0.0.1-SNAPSHOT</version>
        <parent>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-parent</artifactId>
            <version>1.5.17.RELEASE</version>
            <relativePath />
        </parent>
    
        <properties>
            <project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
            <project.reporting.outputEncoding>UTF-8</project.reporting.outputEncoding>
            <java.version>1.8</java.version>
        </properties>
    
        <dependencies>
            <dependency>
                <groupId>org.mybatis.generator</groupId>
                <artifactId>mybatis-generator-core</artifactId>
                <version>1.3.2</version>
            </dependency>
            <dependency>
                <groupId>org.springframework.boot</groupId>
                <artifactId>spring-boot-starter-web</artifactId>
            </dependency>
    
            <dependency>
                <groupId>org.springframework.boot</groupId>
                <artifactId>spring-boot-starter-test</artifactId>
                <scope>test</scope>
            </dependency>
        </dependencies>
    
        <build>
            <plugins>
                <plugin>
                    <groupId>org.springframework.boot</groupId>
                    <artifactId>spring-boot-maven-plugin</artifactId>
                </plugin>
                <plugin>
                    <groupId>org.mybatis.generator</groupId>
                    <artifactId>mybatis-generator-maven-plugin</artifactId>
                    <version>1.3.2</version>
                    <configuration>
                        <verbose>true</verbose>
                        <overwrite>true</overwrite>
                    </configuration>
                </plugin>
            </plugins>
        </build>
    </project>

    五、新建一个配置文件:generatorConfig.xml

    六、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>
        <!-- 配置mysql的驱动(本地仓库中mysql的jar全路径) -->
        <classPathEntry
            location="D:maven
    epositorymysqlmysql-connector-java5.1.46mysql-connector-java-5.1.46.jar" />
        <context id="mysqlTables" targetRuntime="MyBatis3">
    
            <commentGenerator>
                <property name="suppressAllComments" value="true" />
            </commentGenerator>
        
            <!-- 配置数据库连接 -->
            <jdbcConnection driverClass="com.mysql.jdbc.Driver"
                connectionURL="jdbc:mysql://localhost:3306/test" 
                userId="root"
                password="root">
            </jdbcConnection>
    
            <javaTypeResolver>
                <property name="forceBigDecimals" value="false" />
            </javaTypeResolver>
    
            <!-- 生成model模型,对应的包,存放位置可以指定具体的路径,如/ProjectName/src,也可以使用MAVEN来自动生成 -->
            <javaModelGenerator targetPackage="cn.com.winson.domin"
                targetProject="springboot-mybatis/src/main/java">
                <property name="enableSubPackages" value="true" />
                <property name="trimStrings" value="true" />
            </javaModelGenerator>
    
            <!--对应的xml mapper文件 ,目前没有跟dao接口同一目录下,可自行调整与dao同目录-->
            <sqlMapGenerator targetPackage="mybatis"
                targetProject="springboot-mybatis/src/main/resources">
                <property name="enableSubPackages" value="true" />
            </sqlMapGenerator>
    
            <!-- 对应的dao接口 -->
            <javaClientGenerator type="XMLMAPPER"
                targetPackage="cn.com.winson.dao" targetProject="springboot-mybatis/src/main/java">
                <property name="enableSubPackages" value="true" />
            </javaClientGenerator>
    
            <!-- 这里是数据库的表名t_user 以及 POJO类的名字User -->
            <table tableName="t_user" domainObjectName="User"
                enableCountByExample="false" enableSelectByExample="false"
                enableUpdateByExample="false" enableDeleteByExample="false">
            </table>
        </context>
    
    </generatorConfiguration>

      注意:这里有一个大坑,很多博客都没有提到,有一个属性targetProject,它的值必须带上工程名(Project_Name):targetProject="springboot-mybatis/src/main/java",否则后面你会无法运行自动生成文件的程序

     

    七、运行配置文件,自动生成mapper接口、model类、及mapper.xml,注意,不用用run as ->Run MyBatis Generator来操作,如果有错,它不会报出来。

            

    不要用下图方法操作:

     八、错误分析,下面的错误就是因为属性targetProject没有带上工程名(Project_Name)导致的,这是使用上图第一种方法运行配置文件报的错,第二种方法不会有报错提示,这里不做演示。

     九、正确执行配置文件以后,自动生成的目录结构如下图:

    十、总结:

      好了,这就是利用插件自动生成文件的方法,要特别注意我所提到的坑,很多帖子没有提到,我在试验时候,花了好长时间才发现这个问题,浏览了很多帖子,本贴子没有深度讲解各模块的作用及原理,但是你们可以直接把代码拿来复用,节约你们摸索的时间,以后有空,你们再慢慢理解。

    代码地址:https://gitee.com/top_one/SpringBoot_Generator_MyBatis.git

  • 相关阅读:
    定时执行
    history 命令历史
    last
    文件解压缩 tar zip
    硬件信息 dmidecode dmesg lsdev lshw haparm lsusb
    文件加密 解密 pdftk openssl gpg vim
    vim 脚本——插件
    irc
    telnet
    go 垃圾回收机制
  • 原文地址:https://www.cnblogs.com/elnimo/p/10080019.html
Copyright © 2011-2022 走看看