IDEA Maven Mybatis generator 自动生成代码(实例讲解)

下面是详细讲解“IDEA Maven Mybatis generator 自动生成代码(实例讲解)”的完整攻略。

简介

Maven Mybatis generator 是一种可以帮助开发者自动生成 Mybatis 相关代码的工具。它可以根据数据库表的结构,自动生成实体类、Mapper 接口以及 XML Mapper 文件,大大提高了代码编写的效率。

本攻略将会介绍如何使用 IDEA 和 Maven 集成 Mybatis generator 并生成相关模板代码。

步骤

配置 pom.xml 文件

在 pom.xml 文件中添加 Mybatis generator 相关依赖:

<dependencies>
  <!-- Mybatis -->
  <dependency>
    <groupId>org.mybatis</groupId>
    <artifactId>mybatis</artifactId>
    <version>3.5.7</version>
  </dependency>

  <!-- Mybatis generator -->
  <dependency>
    <groupId>org.mybatis.generator</groupId>
    <artifactId>mybatis-generator-core</artifactId>
    <version>1.4.0</version>
  </dependency>

  <!-- Mysql 驱动 -->
  <dependency>
    <groupId>mysql</groupId>
    <artifactId>mysql-connector-java</artifactId>
    <version>8.0.23</version>
  </dependency>
</dependencies>

<build>
  <plugins>
    <!-- Mybatis generator 插件 -->
    <plugin>
      <groupId>org.mybatis.generator</groupId>
      <artifactId>mybatis-generator-maven-plugin</artifactId>
      <version>1.4.0</version>
      <dependencies>
        <dependency>
          <groupId>mysql</groupId>
          <artifactId>mysql-connector-java</artifactId>
          <version>8.0.23</version>
        </dependency>
      </dependencies>
    </plugin>
  </plugins>
</build>

其中,org.mybatis.generator:mybatis-generator-core 是 Mybatis generator 的核心依赖。

配置 generatorConfig.xml 文件

在 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>
  <context id="mysql" targetRuntime="MyBatis3">
    <jdbcConnection driverClass="com.mysql.jdbc.Driver"
      connectionURL="jdbc:mysql://localhost:3306/test?useUnicode=true&amp;characterEncoding=UTF-8&amp;useSSL=false"
      userId="root" password="root">
    </jdbcConnection>

    <javaModelGenerator targetPackage="com.example.demo.model"
      targetProject="src/main/java">
      <property name="enableSubPackages" value="true" />
      <property name="trimStrings" value="true" />
    </javaModelGenerator>

    <sqlMapGenerator targetPackage="com.example.demo.mapper"
      targetProject="src/main/resources">
      <property name="enableSubPackages" value="true" />
    </sqlMapGenerator>

    <javaClientGenerator type="XMLMAPPER"
      targetPackage="com.example.demo.mapper" targetProject="src/main/java">
      <property name="enableSubPackages" value="true" />
    </javaClientGenerator>

    <table tableName="user" domainObjectName="User" />
  </context>
</generatorConfiguration>

其中,主要配置了以下内容:

  • jdbcConnection:数据库连接信息;
  • javaModelGenerator:生成实体类的相关信息;
  • sqlMapGenerator:生成 XML Mapper 文件的相关信息;
  • javaClientGenerator:生成 Mapper 接口的相关信息;
  • table:指定需要生成代码的表名和对应的实体类名称。

在这里,我们生成了一个名为 user 的表的实体类、Mapper 接口和 XML Mapper 文件。

运行 Maven 命令自动生成代码

在 IDEA 中打开 Maven 工具窗口(View -> Tool Windows -> Maven),找到 mybatis-generator 插件的官方命令 mybatis-generator:generate。双击该命令并等待自动化代码生成完成。

另外,也可以通过命令行使用 mvn mybatis-generator:generate 命令来手动运行。

示例一:生成 user 对应的实体类

自动生成的实体类代码:

package com.example.demo.model;

public class User {
    private Integer id;

    private String name;

    private Integer age;

    public Integer getId() {
        return id;
    }

    public void setId(Integer id) {
        this.id = id;
    }

    public String getName() {
        return name;
    }

    public void setName(String name) {
        this.name = name == null ? null : name.trim();
    }

    public Integer getAge() {
        return age;
    }

    public void setAge(Integer age) {
        this.age = age;
    }
}

示例二:生成 user 对应的 Mapper 接口和 XML Mapper 文件

自动生成的 Mapper 接口代码:

package com.example.demo.mapper;

import com.example.demo.model.User;
import com.example.demo.model.UserExample;
import java.util.List;
import org.apache.ibatis.annotations.Param;

public interface UserMapper {
    long countByExample(UserExample example);

    int deleteByExample(UserExample example);

    int deleteByPrimaryKey(Integer id);

    int insert(User record);

    int insertSelective(User record);

    List<User> selectByExample(UserExample example);

    User selectByPrimaryKey(Integer id);

    int updateByExampleSelective(@Param("record") User record, @Param("example") UserExample example);

    int updateByExample(@Param("record") User record, @Param("example") UserExample example);

    int updateByPrimaryKeySelective(User record);

    int updateByPrimaryKey(User record);
}

自动生成的 XML Mapper 文件代码:

<?xml version="1.0" encoding="UTF-8" ?>
<!DOCTYPE mapper
PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN"
"http://mybatis.org/dtd/mybatis-3-mapper.dtd">

<mapper namespace="com.example.demo.mapper.UserMapper">

  <!--
    WARNING - @mbg.generated
    This element is automatically generated by MyBatis Generator, do not modify.
    This element was generated on Mar 29, 2021 at 9:07:50 PM GMT+08:00
  -->
  <resultMap id="BaseResultMap" type="com.example.demo.model.User">
    <id column="id" jdbcType="INTEGER" property="id" />
    <result column="name" jdbcType="VARCHAR" property="name" />
    <result column="age" jdbcType="INTEGER" property="age" />
  </resultMap>

  <!--
    WARNING - @mbg.generated
    This element is automatically generated by MyBatis Generator, do not modify.
    This element was generated on Mar 29, 2021 at 9:07:50 PM GMT+08:00
  -->
  <sql id="Base_Column_List">
    id, name, age
  </sql>

  <select id="selectByExample" resultMap="BaseResultMap" parameterType="com.example.demo.model.UserExample">
    select
    <include refid="Base_Column_List" />
    from user
    <if test="_parameter != null">
      <include refid="Example_Where_Clause" />
    </if>
    <if test="orderByClause != null">
      order by ${orderByClause}
    </if>
  </select>

  <!-- 省略其他自动生成的 SQL 语句 -->

</mapper>

总结

通过使用 Maven Mybatis generator 自动化生成代码,可以大大提高项目开发的效率。以上是整个过程的详细讲解,希望对您有所帮助。

本站文章如无特殊说明,均为本站原创,如若转载,请注明出处:IDEA Maven Mybatis generator 自动生成代码(实例讲解) - Python技术站

(0)
上一篇 2023年5月19日
下一篇 2023年5月19日

相关文章

  • JSP spring boot / cloud 使用filter防止XSS

    下面是详细的JSP Spring Boot/Cloud使用Filter防止XSS的攻略: 什么是XSS攻击 XSS(Cross Site Scripting)攻击是一种非常常见的互联网应用程序攻击,攻击者通过注入恶意脚本代码,在受害者的浏览器中运行这些脚本,从而窃取用户的个人信息或者执行其他危险操作。该攻击方式十分危险,能够威胁到用户的隐私和信息安全,目前已…

    Java 2023年6月15日
    00
  • java实现简单猜拳小游戏

    Java实现简单猜拳小游戏攻略 本文旨在介绍如何使用Java语言实现一个简单的猜拳小游戏。在本文中,我们将涉及如何实现游戏逻辑,如何获取用户输入以及如何进行游戏界面的展示。接下来将详细介绍这些内容。 实现游戏逻辑 在猜拳游戏中,玩家与计算机进行猜拳比赛并决定胜负。为了实现这个过程,我们可以使用Java中的随机数来模拟计算机的猜拳选择,并根据玩家选择和计算机选…

    Java 2023年5月19日
    00
  • Spring中循环依赖的解决方法详析

    Spring中循环依赖的解决方法详析 在 Spring 中,当两个或更多的 Bean 之间存在循环依赖时,会导致容器的初始化过程无法完成,抛出 BeanCurrentlyInCreationException 异常。Spring 提供了三种方式来解决此问题。 1. 通过setter方法注入 在循环依赖的两个或多个 Bean 中,其中一个使用 setter 方…

    Java 2023年5月19日
    00
  • Java之OutputStreamWriter流案例详解

    Java之OutputStreamWriter流案例详解 在Java中,OutputStreamWriter是用于在写入操作时将输出流发送到指定字符编码的字符输出流。本文将详细讲解如何使用OutputStreamWriter流进行写操作。 步骤 创建FileOutputStream类实例,指定写入文件路径。 创建OutputStreamWriter实例,指定…

    Java 2023年5月20日
    00
  • maven profile动态选择配置文件详解

    下面是本人为你准备的maven profile动态选择配置文件的攻略,希望能帮助到你。 什么是maven profile Maven Profile是Maven中的一个重要概念,它定义了一组配置的集合,用来指定开发、测试和生产环境下使用不同的配置。通过设置不同的Profile,可以实现在不同环境下对应用程序的多个设置的更改。 Maven Profile的配置…

    Java 2023年6月2日
    00
  • 简单学习Java抽象类要点及实例

    下面是关于“简单学习Java抽象类要点及实例”的完整攻略。 什么是抽象类 抽象类是一种特殊的类,它不能实例化,只能被继承。抽象类中可以有抽象方法(没有方法体),也可以有非抽象方法(有方法体),但是抽象类中至少要有一个抽象方法。抽象类的主要作用是为了让子类继承并实现它的抽象方法,以此来完成对某个行为的规范和约束。 抽象类的语法 抽象类的语法格式如下: publ…

    Java 2023年5月31日
    00
  • JSONObject按put顺序排放与输出方式

    下面是有关”JSONObject按put顺序排放与输出方式”的攻略。 什么是JSONObject JSONObject是Java中的一个类,可以用于存储和操作JSON格式的数据。它能够将Java对象转换成JSON格式的字符串,也可以将JSON格式的字符串转换成Java对象。 JSONObject按put顺序排放 JSONObject是一种无序的数据结构,它并…

    Java 2023年5月26日
    00
  • 什么是Java编译期注解?

    Java编译期注解是一种在Java编译时期处理的注解,它通过在源代码上附加注释信息的方式,在Java程序编译期处理中对注解进行分析并进行特定处理,从而可以在程序运行期间实现一些自定义功能。 以下是Java编译期注解的一些使用攻略: 1. 创建注解类 首先,我们需要定义一个注解类。注意,注解类的定义必须加上 @interface,以表示它是一个注解。 @Ret…

    Java 2023年5月11日
    00
合作推广
合作推广
分享本页
返回顶部