MBG(Mybatis-Generator)生成代码

目录

步骤:

1. 创建数据库表

2. 配置 MyBatis Generator

3. 运行 MyBatis Generator

4. 编写业务逻辑



在实际开发中,你会发现有很多重复的工作:

首先是PO对象,我们往往创建与数据库表字段一一对应的PO对象;

其次在Mapper里,通常都会写基本的增删改查代码。

解决这个问题,我选择MyBatis Generator, MyBatis Generator是一个用于生成 MyBatis 持久层代码的工具。以下是一个简单的使用 MyBatis Generator 生成代码并编写相应业务逻辑的示例。这个示例假设你已经有一个数据库,并已经准备好了 MyBatis Generator 的配置文件。

步骤:

1. 创建数据库表

在数据库中创建一个表,例如 user 表:

CREATE TABLE user (
    id INT PRIMARY KEY AUTO_INCREMENT,
    username VARCHAR(50),
    password VARCHAR(50)
);
2. 配置 MyBatis Generator

创建 MyBatis Generator 的配置文件 generatorConfig.xml,定义生成器的配置。这个文件通常包含数据库连接信息、生成的代码的目标包路径、表映射等配置。

<!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="DB2Tables" targetRuntime="MyBatis3">
    <commentGenerator>
      <property name="suppressAllComments" value="true" />
    </commentGenerator>
​
    <jdbcConnection driverClass="com.mysql.cj.jdbc.Driver"
                    connectionURL="jdbc:mysql://localhost:3306/your_database"
                    userId="your_username"
                    password="your_password">
    </jdbcConnection>
​
    <javaTypeResolver>
      <property name="forceBigDecimals" value="false" />
    </javaTypeResolver>
​
    <javaModelGenerator targetPackage="com.example.model" targetProject="src/main/java">
      <property name="enableSubPackages" value="true" />
      <property name="trimStrings" value="true" />
    </javaModelGenerator>
​
    <sqlMapGenerator targetPackage="com.example.mapper" targetProject="src/main/resources">
      <property name="enableSubPackages" value="true" />
    </sqlMapGenerator>
​
    <javaClientGenerator type="XMLMAPPER" targetPackage="com.example.mapper" targetProject="src/main/java">
      <property name="enableSubPackages" value="true" />
    </javaClientGenerator>
​
    <table tableName="user" domainObjectName="User" />
  </context>
</generatorConfiguration>

替换其中的 your_databaseyour_usernameyour_password 为你的数据库信息。

3. 运行 MyBatis Generator

在命令行中执行以下命令,运行 MyBatis Generator:

java -jar mybatis-generator-core-x.x.x.jar -configfile generatorConfig.xml -overwrite

这里的 mybatis-generator-core-x.x.x.jar 是 MyBatis Generator 的 JAR 文件,版本号根据实际情况替换。

4. 编写业务逻辑

com.example.model 中生成的 User 类,以及 com.example.mapper 中生成的 UserMapper 接口和对应的 XML 文件。

编写业务逻辑的示例:

// User.java
package com.example.model;
​
public class User {
    private Integer id;
    private String username;
    private String password;
​
    // 省略getter和setter
}
​
// UserMapper.java
package com.example.mapper;
​
import com.example.model.User;
​
public interface UserMapper {
    int insert(User record);
    User selectByPrimaryKey(Integer id);
    // 其他自动生成的方法
}
​
// UserService.java
package com.example.service;
​
import com.example.mapper.UserMapper;
import com.example.model.User;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Service;
​
@Service
public class UserService {
​
    private final UserMapper userMapper;
​
    @Autowired
    public UserService(UserMapper userMapper) {
        this.userMapper = userMapper;
    }
​
    public void addUser(User user) {
        userMapper.insert(user);
    }
​
    public User getUserById(Integer id) {
        return userMapper.selectByPrimaryKey(id);
    }
}

这是一个简单的示例,具体业务逻辑根据实际需求进行扩展。通过 MyBatis Generator 自动生成的代码,你可以轻松地进行数据库访问和操作。

推荐一篇比较详细的文章:5.6 Mybatis代码生成器Mybatis Generator (MBG)实战详解-CSDN博客

  • 34
    点赞
  • 19
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
MyBatis GeneratorMBG)是一个代码生成器,用于为MyBatis和iBATIS生成代码。它可以根据数据库表结构自动生成访问表的代码MBG的主要目的是简化与数据库表交互的初始设置,并减少常见的CRUD(创建,检索,更新,删除)操作的代码编写工作。然而,MBG生成简单的CRUD操作,对于连接查询或存储过程等复杂操作,仍然需要手动编写SQL和对象代码MBG可以生成多种类型的Java客户端类,适用于MyBatis 3.x的映射器接口。这些Java客户端类可以用于与数据库表进行交互。 要使用MyBatis Generator,您需要在项目的pom.xml文件中引入相应的依赖。在plugin标签中配置mybatis-generator-maven-plugin插件,并指定生成配置文件的路径、是否覆盖已有文件以及是否显示详细输出信息。 您可以在pom.xml中的dependencies标签中引入mysql-connector-java依赖,以便在生成代码时与MySQL数据库进行交互。 总结起来,MyBatis Generator是一个用于生成MyBatis和iBATIS代码工具,可以根据数据库表结构自动生成访问表的代码。它可以生成简单的CRUD操作的代码,并且可以生成适用于MyBatis 3.x的Java客户端类。要使用MyBatis Generator,您需要在项目的pom.xml文件中配置相应的插件和依赖。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* *2* *3* [MyBatis Generator使用方法(详细)](https://blog.csdn.net/qq_48581332/article/details/123674440)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_1"}}] [.reference_item style="max-width: 100%"] [ .reference_list ]

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

Elaine202391

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值