Mybatis的逆向工程(原理+详细操作)

一、概念与机制

1、概念

  • 正向工程:先创建Java实体类,由框架负责根据实体类生成数据库表。Hibernate是支持正向工程的。

  • 逆向工程:先创建数据库表,由框架负责根据数据库表,反向生成如下资源:
    Java实体类
    Mapper接口
    Mapper配置文件

2、基本原理

在这里插入图片描述

二、操作

1、配置POM

<!-- 依赖MyBatis核心包 -->
<dependencies>
    <dependency>
        <groupId>org.mybatis</groupId>
        <artifactId>mybatis</artifactId>
        <version>3.5.7</version>
    </dependency>
</dependencies>
    
<!-- 控制Maven在构建过程中相关配置 -->
<build>
        
    <!-- 构建过程中用到的插件 -->
    <plugins>
        
        <!-- 具体插件,逆向工程的操作是以构建过程中插件形式出现的 -->
        <plugin>
            <groupId>org.mybatis.generator</groupId>
            <artifactId>mybatis-generator-maven-plugin</artifactId>
            <version>1.3.0</version>
    
            <!-- 插件的依赖 -->
            <dependencies>
                
                <!-- 逆向工程的核心依赖 -->
                <dependency>
                    <groupId>org.mybatis.generator</groupId>
                    <artifactId>mybatis-generator-core</artifactId>
                    <version>1.3.2</version>
                </dependency>
                    
                <!-- 数据库连接池 -->
                <dependency>
                    <groupId>com.mchange</groupId>
                    <artifactId>c3p0</artifactId>
                    <version>0.9.2</version>
                </dependency>
                    
                <!-- MySQL驱动 -->
                <dependency>
                    <groupId>mysql</groupId>
                    <artifactId>mysql-connector-java</artifactId>
                    <version>5.1.8</version>
                </dependency>
            </dependencies>
        </plugin>
    </plugins>
</build>

2、MBG配置文件

文件名必须是: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>
    <!--
            targetRuntime: 执行生成的逆向工程的版本
                    MyBatis3Simple: 生成基本的CRUD(清新简洁版)
                    MyBatis3: 生成带条件的CRUD(奢华尊享版)
     -->
    <context id="DB2Tables" targetRuntime="MyBatis3">
        <!-- 数据库的连接信息 -->
        <jdbcConnection driverClass="com.mysql.jdbc.Driver"
                        connectionURL="jdbc:mysql://localhost:3306/mybatis-example"
                        userId="root"
                        password="mysql">
        </jdbcConnection>
        <!-- javaBean的生成策略-->
        <javaModelGenerator targetPackage="com.zengchuiyu.mybatis.entity" targetProject=".\src\main\java">
            <property name="enableSubPackages" value="true" />
            <property name="trimStrings" value="true" />
        </javaModelGenerator>
        <!-- SQL映射文件的生成策略 -->
        <sqlMapGenerator targetPackage="com.zengchuiyu.mybatis.mapper"  targetProject=".\src\main\java">
            <property name="enableSubPackages" value="true" />
        </sqlMapGenerator>
        <!-- Mapper接口的生成策略 -->
        <javaClientGenerator type="XMLMAPPER" targetPackage="com.zengchuiyu.mybatis.mapper"  targetProject=".\src\main\java">
            <property name="enableSubPackages" value="true" />
        </javaClientGenerator>
        <!-- 逆向分析的表 -->
        <!-- tableName设置为*号,可以对应所有表,此时不写domainObjectName -->
        <!-- domainObjectName属性指定生成出来的实体类的类名 -->
        <table tableName="t_emp" domainObjectName="Employee"/>
        <table tableName="t_customer" domainObjectName="Customer"/>
        <table tableName="t_order" domainObjectName="Order"/>
    </context>
</generatorConfiguration>

注意:自己配置具体的信息,如数据库连接、包名、对应的表

3、执行MBG插件的generate目标

在这里插入图片描述

4、效果

在这里插入图片描述

三、QBC查询

1、 概念

QBC:Query By Criteria

在这里插入图片描述
QBC查询最大的特点就是将SQL语句中的WHERE子句进行了组件化的封装,让我们可以通过调用Criteria对象的方法自由的拼装查询条件。

2、 例子

/**
 * @author zengchuiyu
 * @create 2021-10-11 0:43
 */
public class QBCTest {

    private SqlSessionFactory factory;

    @Before
    public void init() throws IOException {

        factory = new SqlSessionFactoryBuilder().build(Resources.getResourceAsStream("mybatis-config.xml"));

    }

    @Test
    public void test1(){
        // 1.创建EmployeeExample对象
        EmployeeExample example = new EmployeeExample();

        // 2.通过example对象创建Criteria对象
        EmployeeExample.Criteria criteria01 = example.createCriteria();

        //3.在criteria对象中封装查询条件
        criteria01.andEmpSalaryLessThan(1000.00)
                .andEmpNameLike("%o%");

        SqlSession session = factory.openSession();

        EmployeeMapper mapper = session.getMapper(EmployeeMapper.class);

        //4. 基于Criteria对象进行查询
        List<Employee> employeeList = mapper.selectByExample(example);

        for (Employee employee : employeeList) {
            System.out.println("employee = " + employee);
        }

        session.close();

    }

}

最终效果:

Preparing: select emp_id, emp_name, emp_salary from t_emp WHERE (
emp_salary < ? and emp_name like ? )
[==> Parameters: 1000.0(Double), %o%(String)]

通过逆向工程以及QBC查询可以大大提高开发效率,动态组装我们需要的查询条件。

  • 18
    点赞
  • 70
    收藏
    觉得还不错? 一键收藏
  • 2
    评论
好的,下面详细介绍在IDEA中使用MyBatis逆向工程的具体步骤: 1. 在pom.xml文件中添加MyBatis Generator的依赖: ```xml <dependency> <groupId>org.mybatis.generator</groupId> <artifactId>mybatis-generator-core</artifactId> <version>1.4.0</version> </dependency> ``` 2. 创建MyBatis Generator的配置文件generatorConfig.xml,并配置数据库连接信息、生成代码的规则等。具体配置可以参考MyBatis官方文档。 3. 在IDEA中打开"Maven Projects"窗口,选择要生成代码的项目,展开"Plugins",找到MyBatis Generator插件。 4. 双击"mybatis-generator:generate",在弹出的"Edit Configuration"中,配置如下: - Main Class:org.mybatis.generator.api.ShellRunner - VM options:-Dfile.encoding=UTF-8 - Working directory:$MODULE_DIR$ - Command line:-configfile ${PROJECT_DIR}/src/main/resources/generatorConfig.xml -overwrite 其中,-configfile参数指定了配置文件的路径,-overwrite参数表示覆盖已有文件。 5. 点击"OK"保存配置,再次双击"mybatis-generator:generate",即可生成代码。 执行完毕后,即可在指定的目录下生成Java Bean、Mapper XML及Mapper接口等代码。 另外,如果需要生成代码后自动刷新项目,可以在"Before Launch"中添加"Build",具体步骤如下: - 点击"Add"添加一个新的Before Launch操作。 - 选择"Build",并选择要执行的"Build Project"操作。 - 点击"OK"保存配置。 这样,在生成代码之后,IDEA会自动编译项目,生成的代码就会显示在项目中。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值