步骤:

a.添加mybatis依赖,MySQL驱动

b.使用mybatis提供的逆向工程生成实体bean,映射文件,映射文件,DAO接口

1.新建springboot项目

先建立一个空项目

java逆向工程running mybatis spring逆向工程_spring


在空项目中添加spring项目模块:

java逆向工程running mybatis spring逆向工程_数据库_02


注意:上述Java改选8.

选择依赖:

java逆向工程running mybatis spring逆向工程_spring boot_03


java逆向工程running mybatis spring逆向工程_数据库_04


GeneratorMapper.xml是后来加的。2.往pom.xml文件中添加MySQL依赖

注意pom.xml文件中已含有的依赖:

java逆向工程running mybatis spring逆向工程_spring_05


java逆向工程running mybatis spring逆向工程_数据库_06


添加:

java逆向工程running mybatis spring逆向工程_java_07


第二个是mybatis整合springboot的依赖。

加一个插件:

java逆向工程running mybatis spring逆向工程_java_08

该插件会读取GeneratorMapper.xml配置文件(后面建立)

3.新建一个GeneratorMapper.xml文件(该文件用于识别Dao.xml文件夹、连接数据库并直接将数据库中的表生成对象)

第一部分:

java逆向工程running mybatis spring逆向工程_xml文件_09


generatorConfiguration标记中的classPathEntry的location值填写本地maven库mysql驱动的文件路径,jdbcConnection标记用于连接本地数据库。

第二部分:

java逆向工程running mybatis spring逆向工程_spring boot_10


javaModelGenerator用于与项目中的model文件夹相关联(通过targetPackage值指定),javaMapGenerator用于与项目中的mapper文件夹相关联(通过targetPackage值指定),

javaClientGenerator用于与项目中的mapper文件夹相关联(通过targetPackage值指定).

第三部分:

java逆向工程running mybatis spring逆向工程_数据库_11


table标记用于将数据库中的表生成bean对象,tableName指定数据库中的表的名称,domainObjectName是自定义对象名称,需要用到数据库的几个表就写几个table标记。

本地数据库的表students:

java逆向工程running mybatis spring逆向工程_spring_12


4.使用plugin自动生成文件

java逆向工程running mybatis spring逆向工程_xml文件_13


点击mybatis-generator:generate。

文件自动生成:

java逆向工程running mybatis spring逆向工程_xml文件_14


java逆向工程running mybatis spring逆向工程_spring_15


java逆向工程running mybatis spring逆向工程_java_16


resultMap是表的映射,id和result的区别是id表示主键,其他是普通字段。property映射数据库的属性名称,jdbcType为数据库中字段的名称(该属性可以省略不写)。

sql语句片段是一个小技巧,抽取公共部分。

java逆向工程running mybatis spring逆向工程_数据库_17


等同于:

java逆向工程running mybatis spring逆向工程_数据库_18


接下来讲解方法名中加selective和不加的区别:

java逆向工程running mybatis spring逆向工程_数据库_19


java逆向工程running mybatis spring逆向工程_spring_20


insert方法不考虑插入的对象有的字段为空的情况,而insertSelective考虑了,只有字段不为空才进行插入操作。同理:

java逆向工程running mybatis spring逆向工程_spring boot_21


updateByPrimaryKeySelective在更新是只有更新的数据项的字段不为空时才进行更新操作。而updateByPrimaryKey对每一个字段都进行更新操作。

注意一些逆向工程生成的细节:

(1)Mybatis

逆向工程不区分大小写,只认下划线:

java逆向工程running mybatis spring逆向工程_java_22


注意:数据库中字段名为"userName",实体对象属性名称为"username"。

5.添加控制层和服务层

添加之前先在StudentMapper接口前加注解,将该接口添加到spring容器中:

java逆向工程running mybatis spring逆向工程_xml文件_23


(1)添加服务层

java逆向工程running mybatis spring逆向工程_数据库_24

java逆向工程running mybatis spring逆向工程_spring_25


@Service标记将StudentServiceImpl添加到spring容器中。

(2)控制层

java逆向工程running mybatis spring逆向工程_数据库_26

6.编写配置文件连接数据库(注意:GeneratorMapper.xml只用于逆向工程生成类和xml文件,用完后还是要建立连接数据库的配置文件)

java逆向工程running mybatis spring逆向工程_java_27


java逆向工程running mybatis spring逆向工程_java_28

在pom.xml文件中加一个插件(用于将StudentMapper.xml文件在target文件夹中也生成):

java逆向工程running mybatis spring逆向工程_java_29


java逆向工程running mybatis spring逆向工程_java_30


7.运行主程序(主程序中的@SpringBootApplication注解不能少,它会使项目扫描所有使用的注解,所以注意所有的代码的文件或文件夹要在main程序所在的.java文件位于同一目录下)

java逆向工程running mybatis spring逆向工程_spring boot_31


浏览器中输入网址,回车显示结果:

java逆向工程running mybatis spring逆向工程_xml文件_32


与数据库中的数据一致。

8.@MapperScan注解

注意之前的项目每建立一个xxMapper.java文件就要加一次@Mapper注解,但也可以采用一种更简便的方式:

在main程序所在类加注解@MapperScan,其中basePackages的值指定mapper包路径,这样就会扫描该包下的所有xxMapper.java并将其添加到spring容器中。

java逆向工程running mybatis spring逆向工程_spring boot_33


9.也可以改变xxMapper.xml文件位置,然后在配置文件中说明即可。

java逆向工程running mybatis spring逆向工程_java_34


java逆向工程running mybatis spring逆向工程_数据库_35


10.springboot中添加事务

在方法前添加@Transactional注解

java逆向工程running mybatis spring逆向工程_spring_36


上述int a=10/0;报错,前面对数据库的操作回滚(数据库的值不改变)。

注意:只要是从浏览器发出的请求默认是get。