继续浏览精彩内容
慕课网APP
程序员的梦工厂
打开
继续
感谢您的支持,我会继续努力的
赞赏金额会直接到老师账户
将二维码发送给自己后长按识别
微信支付
支付宝支付

Mybatis代码生成器教程:初学者的快速入门指南

开心每一天1111
关注TA
已关注
手记 524
粉丝 48
获赞 218
概述

Mybatis代码生成器是一种自动化工具,能够自动生成Mapper接口文件、Mapper XML配置文件以及实体类,节省开发人员编写基础代码的时间,提高开发效率。本文将详细介绍Mybatis代码生成器的功能、优势、适用场景及具体配置方法,帮助开发者更好地理解和使用Mybatis代码生成器教程。

Mybatis代码生成器简介

Mybatis代码生成器的功能和作用

Mybatis代码生成器是一种自动化工具,用于自动生成Mybatis所需的Mapper接口文件、Mapper XML配置文件以及实体类。通过代码生成器,开发人员可以节省大量在基础代码编写上的时间,专注于业务逻辑的实现。代码生成器的工作原理是基于数据库表结构,自动生成相关代码文件。具体步骤包括解析数据库表结构,生成相应的Mapper接口及其对应的XML配置文件,以及生成实体类。

Mybatis代码生成器的优势

  1. 减少重复劳动:代码生成器可以自动生成Mapper接口、XML配置文件和实体类,减少了开发人员手工编写这些基础代码的时间。
  2. 提高开发效率:通过自动化工具生成代码,开发人员可以更快地进入业务逻辑的开发阶段,提高开发效率。
  3. 维护方便:代码生成器生成的代码结构一致,有利于代码的维护和团队协作。
  4. 降低出错率:手工编写代码容易出错,而代码生成器可以生成标准格式的代码,减少人为错误。
  5. 适应变化:数据库表结构有变化时,可以通过代码生成器重新生成代码,适应数据库表结构的变化。

Mybatis代码生成器的适用场景

  1. 新项目初始化:在项目初期,可以使用代码生成器生成必要的Mapper接口和实体类,加快项目启动速度。
  2. 数据库表结构变化:当数据库表结构发生变化时,通过代码生成器重新生成代码,适应数据库的变化。
  3. 快速原型开发:在快速原型开发阶段,代码生成器可以快速生成基础代码,便于进行原型验证。
  4. 重构旧项目:对于已有的项目,可以使用代码生成器生成规范的代码,便于后续维护和重构。
  5. 团队协作:团队成员可以使用代码生成器生成的标准化代码,便于协作开发。

Mybatis代码生成器的准备工作

Mybatis环境搭建

Mybatis环境搭建涉及以下几个步骤:

  1. 下载Mybatis:从Mybatis官网下载Mybatis最新版本,并将其添加到项目中。
  2. 配置Mybatis配置文件:创建mybatis-config.xml文件,配置Mybatis的全局配置信息,包括数据库连接信息、日志配置等。
  3. 编写Mapper接口和Mapper XML文件:定义Mapper接口和Mapper XML文件,用于处理数据库操作。
  4. 编写实体类:根据数据库表结构编写对应的实体类。

示例代码:

<!-- mybatis-config.xml -->
<configuration>
    <environments default="development">
        <environment id="development">
            <transactionManager type="JDBC"/>
            <dataSource type="POOLED">
                <property name="driver" value="com.mysql.jdbc.Driver"/>
                <property name="url" value="jdbc:mysql://localhost:3306/mydb"/>
                <property name="username" value="root"/>
                <property name="password" value="password"/>
            </dataSource>
        </environment>
    </environments>
    <mappers>
        <mapper resource="com/example/mybatis/UserMapper.xml"/>
    </mappers>
</configuration>
// UserMapper接口
public interface UserMapper {
    User getUser(int id);
    void insertUser(User user);
    void updateUser(User user);
    void deleteUser(int id);
}
<!-- UserMapper.xml -->
<mapper namespace="com.example.mybatis.UserMapper">
    <select id="getUser" resultType="com.example.mybatis.User">
        SELECT * FROM user WHERE id = #{id}
    </select>
    <insert id="insertUser">
        INSERT INTO user (id, name, email) VALUES (#{id}, #{name}, #{email})
    </insert>
    <update id="updateUser">
        UPDATE user SET name = #{name}, email = #{email} WHERE id = #{id}
    </update>
    <delete id="deleteUser">
        DELETE FROM user WHERE id = #{id}
    </delete>
</mapper>
// User实体类
public class User {
    private int id;
    private String name;
    private String email;

    // 构造函数、getter和setter省略
}

数据库和表的准备

在数据库中创建相应的表结构,以便代码生成器能够自动生成对应的代码。以MySQL为例,创建数据库和表结构如下:

  1. 创建数据库

    CREATE DATABASE mydb;
    USE mydb;
  2. 创建表
    CREATE TABLE user (
    id INT PRIMARY KEY,
    name VARCHAR(50),
    email VARCHAR(100)
    );

Maven项目配置

为了方便项目管理,通常会使用Maven来管理依赖和构建。以下步骤介绍如何在Maven项目中配置Mybatis代码生成器:

  1. 添加Maven依赖
    pom.xml文件中添加Mybatis和代码生成器插件的依赖:

    <dependencies>
    <dependency>
        <groupId>org.mybatis</groupId>
        <artifactId>mybatis</artifactId>
        <version>3.5.6</version>
    </dependency>
    <dependency>
        <groupId>mysql</groupId>
        <artifactId>mysql-connector-java</artifactId>
        <version>8.0.23</version>
    </dependency>
    <!-- 添加代码生成器插件 -->
    <dependency>
        <groupId>org.mybatis.generator</groupId>
        <artifactId>mybatis-generator-core</artifactId>
        <version>1.3.5</version>
    </dependency>
    </dependencies>
  2. 配置Maven插件
    pom.xml文件中添加Mybatis Generator插件的配置:

    <build>
    <plugins>
        <plugin>
            <groupId>org.mybatis.generator</groupId>
            <artifactId>mybatis-generator-maven-plugin</artifactId>
            <version>1.3.7</version>
            <configuration>
                <configurationFile>src/main/resources/mybatis-generator.xml</configurationFile>
                <overwrite>true</overwrite>
            </configuration>
            <dependencies>
                <dependency>
                    <groupId>mysql</groupId>
                    <artifactId>mysql-connector-java</artifactId>
                    <version>8.0.23</version>
                </dependency>
            </dependencies>
        </plugin>
    </plugins>
    </build>
  3. 创建代码生成器配置文件
    src/main/resources/目录下创建mybatis-generator.xml文件,配置代码生成器的参数:
    <mybatisGenerator configurationFile="src/main/resources/mybatis-generator.xml" overwrite="true">
    <classPathEntry path="src/main/resources/mybatis-generator.xml" />
    <context id="DB2Tables" targetRuntime="MyBatis3">
        <jdbcConnection driverClass="com.mysql.jdbc.Driver"
            connectionURL="jdbc:mysql://localhost:3306/mydb"
            userId="root"
            password="password">
        </jdbcConnection>
        <javaModelGenerator targetPackage="com.example.mybatis.model"
            targetProject="src/main/java">
            <property name="enableSubPackages" value="true" />
            <property name="trimStrings" value="true" />
        </javaModelGenerator>
        <sqlMapGenerator targetPackage="com.example.mybatis.mapper"
            targetProject="src/main/java">
            <property name="enableSubPackages" value="true" />
        </sqlMapGenerator>
        <javaClientGenerator type="COMPLEX" targetPackage="com.example.mybatis.mapper"
            targetProject="src/main/java">
            <property name="enableSubPackages" value="true" />
        </javaClientGenerator>
        <table tableName="user" domainObjectName="User" enableCountByExample="false"
            enableUpdateByExample="false" enableDeleteByExample="false" enableSelectByExample="false"
            selectByExampleQueryId="false">
            <generatedKey column="id" sqlType="INTEGER" identity="true" />
        </table>
    </context>
    </mybatisGenerator>

Mybatis代码生成器的使用示例

生成Mapper接口和Mapper XML文件

代码生成器可以根据数据库表结构自动生成Mapper接口和Mapper XML文件。这些文件用于处理数据库操作,如查询、插入、更新和删除。

  1. 配置Mapper接口生成
    mybatis-generator.xml文件中配置生成Mapper接口:

    <javaClientGenerator type="COMPLEX" targetPackage="com.example.mybatis.mapper"
    targetProject="src/main/java">
    <property name="enableSubPackages" value="true" />
    </javaClientGenerator>
  2. 配置Mapper XML生成
    mybatis-generator.xml文件中配置生成Mapper XML文件:
    <sqlMapGenerator targetPackage="com.example.mybatis.mapper"
    targetProject="src/main/java">
    <property name="enableSubPackages" value="true" />
    </sqlMapGenerator>

生成实体类

代码生成器可以根据数据库表结构自动生成实体类。这些实体类用于表示数据库中的表结构。

  1. 配置实体类生成
    mybatis-generator.xml文件中配置生成实体类:
    <javaModelGenerator targetPackage="com.example.mybatis.model"
    targetProject="src/main/java">
    <property name="enableSubPackages" value="true" />
    <property name="trimStrings" value="true" />
    </javaModelGenerator>

示例代码展示

以下是具体的代码生成示例:

<!-- 示例:mybatis-generator.xml 配置文件 -->
<mybatisGenerator configurationFile="src/main/resources/mybatis-generator.xml" overwrite="true">
    <classPathEntry path="/path/to/mysql-connector-java-8.0.23.jar" />
    <context id="DB2Tables" targetRuntime="MyBatis3">
        <jdbcConnection driverClass="com.mysql.jdbc.Driver"
            connectionURL="jdbc:mysql://localhost:3306/mydb"
            userId="root"
            password="password">
        </jdbcConnection>
        <javaModelGenerator targetPackage="com.example.mybatis.model"
            targetProject="src/main/java">
            <property name="enableSubPackages" value="true" />
            <property name="trimStrings" value="true" />
        </javaModelGenerator>
        <sqlMapGenerator targetPackage="com.example.mybatis.mapper"
            targetProject="src/main/java">
            <property name="enableSubPackages" value="true" />
        </sqlMapGenerator>
        <javaClientGenerator type="COMPLEX" targetPackage="com.example.mybatis.mapper"
            targetProject="src/main/java">
            <property name="enableSubPackages" value="true" />
        </javaClientGenerator>
        <table tableName="user" domainObjectName="User" enableCountByExample="false"
            enableUpdateByExample="false" enableDeleteByExample="false" enableSelectByExample="false"
            selectByExampleQueryId="false">
            <generatedKey column="id" sqlType="INTEGER" identity="true" />
        </table>
    </context>
</mybatisGenerator>
// 示例:UserMapper接口
public interface UserMapper {
    User getUser(int id);
    void insertUser(User user);
    void updateUser(User user);
    void deleteUser(int id);
}
<!-- 示例:UserMapper.xml -->
<mapper namespace="com.example.mybatis.UserMapper">
    <select id="getUser" resultType="com.example.mybatis.User">
        SELECT * FROM user WHERE id = #{id}
    </select>
    <insert id="insertUser">
        INSERT INTO user (id, name, email) VALUES (#{id}, #{name}, #{email})
    </insert>
    <update id="updateUser">
        UPDATE user SET name = #{name}, email = #{email} WHERE id = #{id}
    </update>
    <delete id="deleteUser">
        DELETE FROM user WHERE id = #{id}
    </delete>
</mapper>

Mybatis代码生成器的进阶设置

自定义生成模板

代码生成器支持自定义生成模板,可以根据项目需求生成特定格式的代码。例如,可以自定义Mapper接口、Mapper XML文件和实体类的模板。

  1. 配置自定义模板
    mybatis-generator.xml文件中配置自定义模板:

    <javaClientGenerator type="SINGLE" targetPackage="com.example.mybatis.mapper"
    targetProject="src/main/java"
    templateLocation="/path/to/custom/templates">
    <property name="enableSubPackages" value="true" />
    </javaClientGenerator>
  2. 创建自定义模板文件
    在指定路径下创建自定义模板文件,如Mapper.javaMapper.xml模板文件。

调整生成代码的格式和风格

代码生成器允许调整生成代码的格式和风格,例如缩进、换行、注释等。这可以通过配置文件中的属性来实现。

  1. 配置生成代码格式
    mybatis-generator.xml文件中配置生成代码的格式:

    <javaModelGenerator targetPackage="com.example.mybatis.model"
    targetProject="src/main/java">
    <property name="enableSubPackages" value="true" />
    <property name="trimStrings" value="true" />
    <property name="fileEncoding" value="UTF-8" />
    </javaModelGenerator>
  2. 配置生成代码风格
    mybatis-generator.xml文件中配置生成代码的风格:
    <javaClientGenerator type="COMPLEX" targetPackage="com.example.mybatis.mapper"
    targetProject="src/main/java">
    <property name="enableSubPackages" value="true" />
    <property name="fileEncoding" value="UTF-8" />
    </javaClientGenerator>

代码生成的自动化集成

代码生成器可以与构建工具(如Maven或Gradle)集成,实现自动化生成代码。这可以通过配置Maven插件或Gradle任务来实现。

  1. 配置Maven插件
    pom.xml文件中配置Maven插件:

    <build>
    <plugins>
        <plugin>
            <groupId>org.mybatis.generator</groupId>
            <artifactId>mybatis-generator-maven-plugin</artifactId>
            <version>1.3.7</version>
            <configuration>
                <configurationFile>src/main/resources/mybatis-generator.xml</configurationFile>
                <overwrite>true</overwrite>
            </configuration>
            <dependencies>
                <dependency>
                    <groupId>mysql</groupId>
                    <artifactId>mysql-connector-java</artifactId>
                    <version>8.0.23</version>
                </dependency>
            </dependencies>
        </plugin>
    </plugins>
    </build>
  2. 配置Gradle任务
    build.gradle文件中配置Gradle任务:
    
    apply plugin: 'mybatis-generator'

mybatisGenerator {
configurationFile = 'src/main/resources/mybatis-generator.xml'
overwrite = true
classpath = configurations.compile
}



### 常见问题及解决方案

#### 解决生成过程中遇到的常见错误
在代码生成过程中可能会遇到各种错误,如数据库连接错误、表结构解析错误等。以下是常见的错误及其解决方案:

1. **数据库连接错误**:
   - **错误信息**:`Could not get connection to the database`
   - **解决方案**:检查数据库连接信息是否正确,确保数据库服务已启动。

2. **表结构解析错误**:
   - **错误信息**:`Could not parse table definition`
   - **解决方案**:检查表结构是否正确,确保表名和字段名符合规范。

3. **文件生成错误**:
   - **错误信息**:`Failed to generate file`
   - **解决方案**:检查生成文件的目标路径是否正确,确保目标目录存在且可写。

#### 代码生成器性能优化
代码生成器的性能可以通过以下方式进行优化:

1. **优化数据库连接**:
   - 使用连接池管理数据库连接,提高连接的复用率。
   - 配置合理的连接超时时间,减少连接等待时间。

2. **优化表结构解析**:
   - 使用索引查询表结构,减少解析时间。
   - 缓存已解析的表结构信息,减少重复解析。

3. **优化生成代码格式**:
   - 通过配置减少生成代码的冗余信息,提高代码的紧凑性。
   - 采用并行生成方式,利用多线程提高生成速度。

#### 更新代码生成器的注意事项
在更新代码生成器时需要注意以下几点:

1. **备份现有代码**:
   - 在更新前备份现有的Mapper接口、Mapper XML文件和实体类,防止生成过程中的代码替换丢失原有业务逻辑。

2. **测试新版本**:
   - 更新后先在开发环境中进行测试,确保新版本的代码生成器能够正常工作。
   - 检查生成的代码是否符合项目规范和要求。

3. **逐步迁移**:
   - 如果项目规模较大,可以逐步迁移,先在新版本中生成部分代码,逐步替换旧版本代码,减少风险。

### 总结
Mybatis代码生成器是一种强大的工具,能够帮助开发人员快速生成Mybatis所需的Mapper接口、Mapper XML文件和实体类。通过合理配置和使用代码生成器,可以提高开发效率,减少重复劳动,保证代码的一致性和规范性。随着项目的不断发展,代码生成器的使用会变得更加重要,因此建议开发人员掌握代码生成器的配置和使用方法。更多关于Mybatis和代码生成器的知识,可以在[M慕课网](https://www.imooc.com/)上进行学习。
打开App,阅读手记
0人推荐
发表评论
随时随地看视频慕课网APP