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

yizhihongxing

下面是详细讲解“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日

相关文章

  • JAVA实现打印ascii码表代码

    下面是JAVA实现打印ASCII码表的完整攻略: 步骤一:了解ASCII码表 ASCII码(American Standard Code for Information Interchange 美国信息交换标准代码)是一种字符编码方式,使用数字127来表示128个字符(包括字母、数字和符号),它们分别对应不同的ASCII码值。了解ASCII码表对于编写打印A…

    Java 2023年5月23日
    00
  • 详解Java中的JDK、JRE、JVM

    详解Java中的JDK、JRE、JVM 在学习 Java 时,经常会听到三个概念:JDK、JRE、JVM。那么,JDK、JRE、JVM 的含义和作用各是什么呢?本文将详解解释。 JDK JDK(Java Development Kit)即 Java 开发工具包,是开发 Java 程序所必需的。JDK 包括两部分内容:一是 JRE(Java Runtime E…

    Java 2023年5月19日
    00
  • 消息队列-kafka消费异常问题

    消息队列-kafka消费异常问题主要包括以下几个方面: 消费者异常退出问题 重复消费问题 消费速度慢导致的积压现象 我们将针对以上问题逐一展开讲解,包括其原因和解决方法。 1. 消费者异常退出问题 消费者异常退出问题,主要发生在程序崩溃或机器宕机等情况下。这种情况下,消息队列的消费进度会被打回,并且消息会重新消费一遍,导致重复消费问题。 解决这个问题的方法是…

    Java 2023年5月20日
    00
  • RocketMQ ConsumeQueue与IndexFile实时更新机制源码解析

    RocketMQ ConsumeQueue与IndexFile实时更新机制源码解析 RocketMQ是一个高性能、高可靠、可伸缩、分布式的消息中间件。在消息投递和消费的过程中,RocketMQ的ConsumeQueue与IndexFile起到了至关重要的作用,本篇文章将对其实时更新机制进行源码解析。 ConsumeQueue介绍 ConsumeQueue是R…

    Java 2023年5月20日
    00
  • 30条Java代码编写经验分享

    30条Java代码编写经验分享 本文提供30条Java代码编写经验分享,涵盖了Java编程中的许多方面,包括变量、模块化、异常处理、性能优化、安全性等方面,旨在帮助读者提高Java编程技能,避免常见的错误和陷阱。下面对这些经验进行详细解释。 1. 变量和数据类型 1.1 千万不要在循环体内定义变量。循环体内定义的变量会在每次循环迭代时重新创建和销毁,会严重降…

    Java 2023年5月23日
    00
  • Java负载均衡算法实现之轮询和加权轮询

    下面是详细讲解Java负载均衡算法实现之轮询和加权轮询的完整攻略。 1. 负载均衡简介 负载均衡是指将工作负载分摊到多个处理单元上,以达到更好的性能、可扩展性和可靠性,可以被应用于各种计算系统中,包括数据库、Web服务器、应用服务器等等。负载均衡算法就是如何分配负载到各个处理单元的问题。 2. 轮询算法 轮询算法是最常见的负载均衡算法之一,其基本原理是按照事…

    Java 2023年5月19日
    00
  • maven springboot如何将jar包打包到指定目录

    为了将 Maven SpringBoot 项目打包为指定目录下的 jar 包,可以按照以下步骤进行操作: 1. 配置 pom.xml 文件 首先需要在项目的 pom.xml 文件中添加以下配置: <build> <plugins> <plugin> <groupId>org.springframework.bo…

    Java 2023年6月2日
    00
  • Spring boot admin 服务监控利器详解

    Spring Boot Admin 服务监控利器详解 Spring Boot Admin 是一个用于管理和监控 Spring Boot 应用程序的开源项目。它提供了一个简单易用的 Web 界面,可以帮助我们监控应用程序的运行状态、性能指标和日志信息等。在本文中,我们将详细讲解 Spring Boot Admin 的使用方法,并提供两个示例。 添加依赖 在po…

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