MyBatis学习笔记之逆向工程


所谓的逆向工程是:根据数据库表逆向生成的Java的pojo类、SqlMapper.xml文件、以及mapper接口类等
要完成这个工作,需要借助别人写好的逆向工程插件。

虽然有点经典白学,但好像也没不白学


思考:使用这个插件的话,需要给这个插件配置哪些信息?

  • pojo类名、包名以及生成的位置。
  • SqlMapper.xml文件名以及生成的位置
  • Mapper接口名以及生成的位置
  • 连接数据库的信息
  • 指定哪些表

逆向工程配置与生成

pom.xml配置

   <!--配置mybatis逆向工程的插件-->
    <!--定制构建过程-->
    <build>
        <!--可以配置多个插件-->
        <plugins>
            <!--其中的一个插件:mybatis逆向工程插件-->
            <plugin>
                <!--插件的GAV坐标-->
                <groupId>org.mybatis.generator</groupId>
                <artifactId>mybatis-generator-maven-plugin</artifactId>
                <version>1.4.1</version>
                <!--允许覆盖-->
                <configuration>
                    <overwrite>true</overwrite>
                </configuration>
                <!--插件的依赖-->
                <dependencies>
                    <!--mysql驱动依赖-->
                    <dependency>
                        <groupId>mysql</groupId>
                        <artifactId>mysql-connector-java</artifactId>
                        <version>8.0.30</version>
                    </dependency>
                </dependencies>
            </plugin>
        </plugins>
    </build>

配置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:生成的是基础版,只有基本的增删改查。-->
    <!--MyBatis3:生成的是增强版,除本的增副改查之外还有复杂的增副改查。-->
    <context id="DB2Tables" targetRuntime="MyBatis3">
        <!--防止生成重复代码-->
        <plugin type="org.mybatis.generator.plugins.UnmergeableXmlMappersPlugin"/>
        <commentGenerator>
            <!--是否去掉生成日期-->
            <property name="suppressDate" value="true"/>
            <!--是否去除注释-->
            <property name="suppressAllComments" value="true"/>
        </commentGenerator>
        <!--连接数据库信息-->
        <jdbcConnection driverClass="com.mysql.cj.jdbc.Driver"
                        connectionURL="jdbc:mysql://localhost:3306/demo"
                        userId="root"
                        password="root">
        </jdbcConnection>
        <!--        生成pojo包名和位置-->
        <javaModelGenerator targetPackage="com.powernode.mybatis.pojo"
                            targetProject="src/main/java">
            <!--            是否开启子包-->
            <property name="enableSunPackages" value="true"/>
            <!--            是否去除字段名的前后空白-->
            <property name="trimStrings" value="true"/>
        </javaModelGenerator>
        <!--        生成SQL映射文件的包名和位置-->
        <sqlMapGenerator targetPackage="com.powernode.mybatis.mapper"
                         targetProject="src/main/resources">
            <!--            是否开启了子包-->
            <property name="enableSubPackages" value="true"/>
        </sqlMapGenerator>
        <!--        生成Mapper接包名口的和位置-->
        <javaClientGenerator
                type="xmlMapper"
                targetPackage="com.powernode.mybatis.mapper"
                targetProject="src/main/java">
            <property name="enableSubPackages" value="true"/>
        </javaClientGenerator>
        <!--        表名和对应的实体类名-->
        <table tableName="t_car" domainObjectName="Car"/>
    </context>
</generatorConfiguration>

在配置完之后,只要老铁双击六六六就可以搭建起来了
在这里插入图片描述

QBC查询风格

在成功创建之后会发现pojo里面有一个CarExample,这玩意是为了来封装的

QBC风格:Query By Criteria 一种查询方式,比较面向对象,看不到sql语句。

@Test
public void test(){
    SqlSession sqlSession = SqlSessionUtil.openSession();
    CarMapper mapper = sqlSession.getMapper(CarMapper.class);
    CarExample carExample = new CarExample();
    carExample.createCriteria().andBrandEqualTo("阿巴阿巴");
    carExample.or().andCarTypeEqualTo("燃油车");
    sqlSession.close();
}
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

打赏作者

优降宁

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

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

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

打赏作者

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

抵扣说明:

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

余额充值