SpringBoot与Mybatis的逆向工程

温馨提示:若不是特别急或已经掌握原流程,建议还是老老实实敲代码,才能加深理解。

于Hibernate中存在一种“正向工程”,可以将实体类中的内容生成相应字段的数据库表,自从了解到这一知识点后我便一直在想:难道spring官方推荐的mybatis就这么拉胯吗?没有什么加快开发的手段?于是今天的主角他来了-----mybatis逆向工程。

mybatis逆向工程,光是听也明白大概是什么意思了,也就是与Hibernate的正向工程相反,既将数据库表中的字段生成为对应的实体类。但他远不止如此,他还能生成sql映射文件与Mapper接口,功能完备且强大。

最关键的是,即使你的数据库表中字段是以下划线分割的,生成的实体类中依然会小写开头的驼峰命名法,且他自动完美解决了由于字段不统一造成的查询数据为空的问题。

接下来,废话不多说,上才艺!!!

首先这是我的目录

 1、将pom文件中的build代码段修改为如下

<build>
        <plugins>
            <plugin>
                <groupId>org.springframework.boot</groupId>
                <artifactId>spring-boot-maven-plugin</artifactId>
            </plugin>
            <!-- mybatis  逆向工程依赖 -->
            <plugin>
                <groupId>org.mybatis.generator</groupId>
                <artifactId>mybatis-generator-maven-plugin</artifactId>
                <version>1.3.5</version>
                <configuration>
                    <verbose>false</verbose>
                    <overwrite>false</overwrite>
                </configuration>
                <dependencies>
                    <dependency>
                        <groupId>mysql</groupId>
                        <artifactId>mysql-connector-java</artifactId>
                        <version>8.0.28</version>
                    </dependency>
                </dependencies>
            </plugin>
        </plugins>
        <resources>
            <resource>
                <directory>src/main/java</directory>
                <!-- 此配置不可缺,否则mybatis的Mapper.xml将会丢失 -->
                <includes>
                    <include>**/*.xml</include>
                </includes>
            </resource>
            <!--指定资源的位置-->
            <resource>
                <directory>src/main/</directory>
                <includes>
                    <include>**/*.properties</include>
                </includes>
            </resource>
        </resources>
    </build>

2、于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>
    <!--
    targetRuntime: 执行逆向工程的版本
    MyBatis3Simple: 生成基本的CRUD(清新简洁版)
    MyBatis3: 生成带条件的CRUD(奢华尊享版)
    -->
    <context id="DB2Tables" targetRuntime="MyBatis3">
        <commentGenerator>
            <!-- 是否去除自动生成的注释。true:去除 false:不去除 -->
            <property name="suppressAllComments" value="true"/>
        </commentGenerator>
        <!-- 数据库的连接信息 -->
        <jdbcConnection driverClass="com.mysql.cj.jdbc.Driver"
                        connectionURL="jdbc:mysql://localhost:3306/books_admin"
                        userId="root"
                        password="******">
        </jdbcConnection>
        <!-- javaBean的生成策略-->
        <javaModelGenerator targetPackage="com.BooksAdmin.pojo" targetProject=".\src\main\java">
            <property name="enableSubPackages" value="true" />
            <property name="trimStrings" value="true" />
        </javaModelGenerator>
        <!-- SQL映射文件的生成策略 -->
        <sqlMapGenerator targetPackage="mybatis.mapper"
                         targetProject=".\src\main\resources">
            <property name="enableSubPackages" value="true" />
        </sqlMapGenerator>
        <!-- Mapper接口的生成策略 -->
        <javaClientGenerator type="XMLMAPPER"
                             targetPackage="com.BooksAdmin.mapper" targetProject=".\src\main\java">
            <property name="enableSubPackages" value="true" />
        </javaClientGenerator>
        <!-- 逆向分析的表 -->
        <!-- tableName设置为*号,可以对应所有表,此时不写domainObjectName -->
        <!-- domainObjectName属性指定生成出来的实体类的类名 -->
        <table tableName="admin" domainObjectName="Admin"/>
        <table tableName="book_list" domainObjectName="BookList"/>
        <table tableName="book_order" domainObjectName="BookOrder"/>
        <table tableName="img" domainObjectName="Img"/>
        <table tableName="token" domainObjectName="Token"/>
        <table tableName="user_list" domainObjectName="UserList"/>
    </context>
</generatorConfiguration>

3、于核心配置文件application.yml中配置如下信息

mybatis:
  type-aliases-package: com.BooksAdmin.pojo
  mapper-locations: classpath:mybatis/mapper/*.xml
#  逆向工程配置,完成逆向工程后,请将以下 ↓ 代码段注释或删除
  config-location: classpath:generatorConfig.xml

4、于maven中执行逆向工程

至此,你就完成了逆向工程。

注意事项:

1.若generatorConfig.xml文件中头部存在报错,正如注释所说别管。

如果你有强迫症,那好吧。加入以下依赖即可

<!-- https://mvnrepository.com/artifact/org.mybatis.generator/mybatis-generator-core -->
        <dependency>
            <groupId>org.mybatis.generator</groupId>
            <artifactId>mybatis-generator-core</artifactId>
            <version>1.3.7</version>
        </dependency>

2.完成逆向工程后,请务必执行第三步,代码段中的注释内容

3.完成逆向工程后,无论有没有,都请重写实体类中的toString方法和构造方法(全参和无参),以Example为结尾的实体类则不用管

4.如数据库字段改变需要重新运行逆向工程,请将之前的所有生成的文件删除以防再次生成配置信息;或者手动添加实体类的字段。

也许,你会说,这样生成的代码无法完成一些复杂的业务逻辑;是的,他确实无法完成一些太复杂的场景,但完备的增删改查一定也会对你有所助益。

即便如此,他的自定义条件查询,动态sql,字段映射都使我在初次使用时大受震撼,也能体会到什么叫越学就越发感到自己无知,体会到人的有限性。

说回开头,若是你仍未掌握springboot-mybatis的全套流程请慎重使用,毕竟只有手打代码才能让你对这套流程更加理解。

  • 1
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 2
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值