springboot集成mybatis(使用逆向工程)

步骤:
a.添加mybatis依赖,MySQL驱动
b.使用mybatis提供的逆向工程生成实体bean,映射文件,映射文件,DAO接口
1.新建springboot项目
先建立一个空项目
springboot集成mybatis(使用逆向工程)_第1张图片
在空项目中添加spring项目模块:
springboot集成mybatis(使用逆向工程)_第2张图片
选择依赖:
springboot集成mybatis(使用逆向工程)_第3张图片
springboot集成mybatis(使用逆向工程)_第4张图片
GeneratorMapper.xml是后来加的。

2.往pom.xml文件中添加MySQL依赖
注意pom.xml文件中已含有的依赖:
springboot集成mybatis(使用逆向工程)_第5张图片
springboot集成mybatis(使用逆向工程)_第6张图片
添加:
springboot集成mybatis(使用逆向工程)_第7张图片
第二个是mybatis整合springboot的依赖。
加一个插件:
springboot集成mybatis(使用逆向工程)_第8张图片

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

3.新建一个GeneratorMapper.xml文件(该文件用于识别Dao.xml文件夹、连接数据库并直接将数据库中的表生成对象)
第一部分:
springboot集成mybatis(使用逆向工程)_第9张图片
generatorConfiguration标记中的classPathEntry的location值填写本地maven库mysql驱动的文件路径,jdbcConnection标记用于连接本地数据库。
第二部分:
springboot集成mybatis(使用逆向工程)_第10张图片
javaModelGenerator用于与项目中的model文件夹相关联(通过targetPackage值指定),javaMapGenerator用于与项目中的mapper文件夹相关联(通过targetPackage值指定),
javaClientGenerator用于与项目中的mapper文件夹相关联(通过targetPackage值指定).
第三部分:
springboot集成mybatis(使用逆向工程)_第11张图片
table标记用于将数据库中的表生成bean对象,tableName指定数据库中的表的名称,domainObjectName是自定义对象名称,需要用到数据库的几个表就写几个table标记。
本地数据库的表students:
springboot集成mybatis(使用逆向工程)_第12张图片
4.使用plugin自动生成文件
springboot集成mybatis(使用逆向工程)_第13张图片
点击mybatis-generator:generate。
文件自动生成:
springboot集成mybatis(使用逆向工程)_第14张图片
springboot集成mybatis(使用逆向工程)_第15张图片
springboot集成mybatis(使用逆向工程)_第16张图片
resultMap是表的映射,id和result的区别是id表示主键,其他是普通字段。property映射数据库的属性名称,jdbcType为数据库中字段的名称(该属性可以省略不写)。
sql语句片段是一个小技巧,抽取公共部分。
springboot集成mybatis(使用逆向工程)_第17张图片
等同于:
在这里插入图片描述
接下来讲解方法名中加selective和不加的区别:
springboot集成mybatis(使用逆向工程)_第18张图片
springboot集成mybatis(使用逆向工程)_第19张图片
insert方法不考虑插入的对象有的字段为空的情况,而insertSelective考虑了,只有字段不为空才进行插入操作。同理:
springboot集成mybatis(使用逆向工程)_第20张图片
updateByPrimaryKeySelective在更新是只有更新的数据项的字段不为空时才进行更新操作。而updateByPrimaryKey对每一个字段都进行更新操作。
注意一些逆向工程生成的细节:
(1)Mybatis
逆向工程不区分大小写,只认下划线:
在这里插入图片描述
注意:数据库中字段名为"userName",实体对象属性名称为"username"。
5.添加控制层和服务层
添加之前先在StudentMapper接口前加注解,将该接口添加到spring容器中:
springboot集成mybatis(使用逆向工程)_第21张图片
(1)添加服务层
springboot集成mybatis(使用逆向工程)_第22张图片

springboot集成mybatis(使用逆向工程)_第23张图片
@Service标记将StudentServiceImpl添加到spring容器中。
(2)控制层
springboot集成mybatis(使用逆向工程)_第24张图片

6.编写配置文件连接数据库(注意:GeneratorMapper.xml只用于逆向工程生成类和xml文件,用完后还是要建立连接数据库的配置文件)
springboot集成mybatis(使用逆向工程)_第25张图片
springboot集成mybatis(使用逆向工程)_第26张图片

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

springboot集成mybatis(使用逆向工程)_第27张图片
springboot集成mybatis(使用逆向工程)_第28张图片
7.运行主程序(主程序中的@SpringBootApplication注解不能少,它会使项目扫描所有使用的注解,所以注意所有的代码的文件或文件夹要在main程序所在的.java文件位于同一目录下)
springboot集成mybatis(使用逆向工程)_第29张图片
浏览器中输入网址,回车显示结果:
springboot集成mybatis(使用逆向工程)_第30张图片
与数据库中的数据一致。
8.@MapperScan注解
注意之前的项目每建立一个xxMapper.java文件就要加一次@Mapper注解,但也可以采用一种更简便的方式:
在main程序所在类加注解@MapperScan,其中basePackages的值指定mapper包路径,这样就会扫描该包下的所有xxMapper.java并将其添加到spring容器中。
springboot集成mybatis(使用逆向工程)_第31张图片
9.也可以改变xxMapper.xml文件位置,然后在配置文件中说明即可。
springboot集成mybatis(使用逆向工程)_第32张图片
springboot集成mybatis(使用逆向工程)_第33张图片
10.springboot中添加事务
在方法前添加@Transactional注解
springboot集成mybatis(使用逆向工程)_第34张图片
上述int a=10/0;报错,前面对数据库的操作回滚(数据库的值不改变)。
注意:只要是从浏览器发出的请求默认是get。

你可能感兴趣的:(spring,boot,java)