详解mybatis generator代码生成器的使用

时间:2022-09-22 20:36:04

MyBatis Generator简介

MyBatis Generator(MBG)是MyBatis MyBatis 和iBATIS的代码生成器。它将为所有版本的MyBatis以及版本2.2.0之后的iBATIS版本生成代码。它将内省数据库表(或许多表),并将生成可用于访问表的工件。这减少了设置对象和配置文件以与数据库表交互的初始麻烦。MBG寻求对简单CRUD(创建,检索,更新,删除)的大部分数据库操作产生重大影响。您仍然需要为连接查询或存储过程手动编写SQL和对象代码。

MyBatis Generator下载

1.源码地址: https://github.com/mybatis/generator/releases

2.官方文档: http://www.mybatis.org/generator/index.html

下面看下mybatis generator代码生成器的使用,开始结构图如下:

详解mybatis generator代码生成器的使用

maven文件引入

<?xml version="1.0" encoding="UTF-8"?>
<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/xsd/maven-4.0.0.xsd">
  <modelVersion>4.0.0</modelVersion>

  <groupId>com.ding</groupId>
  <artifactId>mybatis_generator</artifactId>
  <version>1.0-SNAPSHOT</version>
<dependencies>
  <dependency>
      <groupId>org.mybatis.generator</groupId>
      <artifactId>mybatis-generator-core</artifactId>
      <version>1.3.7</version>
  </dependency>
  <dependency>
      <groupId>org.mybatis</groupId>
      <artifactId>mybatis</artifactId>
      <version>3.5.7</version>
      <scope>compile</scope>
  </dependency>


</dependencies>
  <build>
      <plugins>
          <plugin>
              <groupId>org.mybatis.generator</groupId>
              <artifactId>mybatis-generator-maven-plugin</artifactId>
              <version>1.3.2</version>
              <configuration>
                  <!--配置文件的位置-->
                  <configurationFile>
                      src/main/resources/generatorConfig.xml
                  </configurationFile>
              </configuration>
          </plugin>
      </plugins>
  </build>
</project>

数据库

| Create Table                                       |
| -------------------------------------------------- |
| CREATE TABLE `student` (                           |
| `id` int(11) NOT NULL AUTO_INCREMENT,              |
| `NAME` varchar(20) DEFAULT NULL,                   |
| `age` int(11) DEFAULT NULL,                        |
| PRIMARY KEY (`id`)                                 |
| ) ENGINE=InnoDB AUTO_INCREMENT=4 DEFAULT CHARSET=u |

编写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>
  <!--数据库驱动写自己jar包的位置-->
  <classPathEntry location="D:\develop\apache-maven-3.6.1\mvn_repository\mysql\mysql-connector-java\5.1.47\mysql-connector-java-5.1.47.jar"/>
  <!-- 一个数据库一个context -->
  <context id="MYTables" targetRuntime="MyBatis3">
      <commentGenerator>
          <!--suppressDate:**阻止**生成的注释包含时间戳-->
          <property name="suppressDate" value="true"/>
          <!--suppressAllComments:**阻止**生成注释-->
          <property name="suppressAllComments" value="true"/>
      </commentGenerator>
      <!--数据库链接地址账号密码-->
      <jdbcConnection driverClass="com.mysql.jdbc.Driver"
                      connectionURL="jdbc:mysql://localhost:3306/db1"
                      userId="root" password="root">
      </jdbcConnection>
      <javaTypeResolver>
          <!--控制是否强制DECIMAL和NUMERIC类型的字段转换为Java类型的
          java.math.BigDecimal-->
          <property name="forceBigDecimals" value="false"/>
      </javaTypeResolver>
      <!--生成Model类存放位置-->
      <javaModelGenerator targetPackage="com.ding.pojo"
                          targetProject="src\main\java">
          <property name="enableSubPackages" value="true"/>
          <property name="trimStrings" value="true"/>
      </javaModelGenerator>
      <!--生成映射文件存放位置-->
      <sqlMapGenerator targetPackage="mapper"
                       targetProject="src\main\resources">
          <property name="enableSubPackages" value="true"/>
      </sqlMapGenerator>
      <!--生成Dao类存放位置-->
      <javaClientGenerator type="XMLMAPPER" targetPackage="com.ding.dao"
                           targetProject="src\main\java">
          <property name="enableSubPackages" value="true"/>
      </javaClientGenerator>
      <!--生成对应表及类名-->
      <table tableName="student" domainObjectName="student" enableCountByExample="false" enableUpdateByExample="false" enableDeleteByExample="false" enableSelectByExample="false" selectByExampleQueryId="false"/>

  </context>
</generatorConfiguration>

生成

详解mybatis generator代码生成器的使用

生成后的结构图

详解mybatis generator代码生成器的使用

世界不会因为你的疲惫,而停下它的脚步

到此这篇关于mybatis generator代码生成器的使用的文章就介绍到这了,更多相关mybatis generator代码生成器内容请搜索服务器之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持服务器之家!

原文链接:https://www.cnblogs.com/dss-99/p/15312779.html