温馨提示:若不是特别急或已经掌握原流程,建议还是老老实实敲代码,才能加深理解。
于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的全套流程请慎重使用,毕竟只有手打代码才能让你对这套流程更加理解。