步骤:
a.添加mybatis依赖,MySQL驱动
b.使用mybatis提供的逆向工程生成实体bean,映射文件,映射文件,DAO接口
1.新建springboot项目
先建立一个空项目
在空项目中添加spring项目模块:
注意:上述Java改选8.
选择依赖:
GeneratorMapper.xml是后来加的。2.往pom.xml文件中添加MySQL依赖
注意pom.xml文件中已含有的依赖:
添加:
第二个是mybatis整合springboot的依赖。
加一个插件:
该插件会读取GeneratorMapper.xml配置文件(后面建立)
3.新建一个GeneratorMapper.xml文件(该文件用于识别Dao.xml文件夹、连接数据库并直接将数据库中的表生成对象)
第一部分:
generatorConfiguration标记中的classPathEntry的location值填写本地maven库mysql驱动的文件路径,jdbcConnection标记用于连接本地数据库。
第二部分:
javaModelGenerator用于与项目中的model文件夹相关联(通过targetPackage值指定),javaMapGenerator用于与项目中的mapper文件夹相关联(通过targetPackage值指定),
javaClientGenerator用于与项目中的mapper文件夹相关联(通过targetPackage值指定).
第三部分:
table标记用于将数据库中的表生成bean对象,tableName指定数据库中的表的名称,domainObjectName是自定义对象名称,需要用到数据库的几个表就写几个table标记。
本地数据库的表students:
4.使用plugin自动生成文件
点击mybatis-generator:generate。
文件自动生成:
resultMap是表的映射,id和result的区别是id表示主键,其他是普通字段。property映射数据库的属性名称,jdbcType为数据库中字段的名称(该属性可以省略不写)。
sql语句片段是一个小技巧,抽取公共部分。
等同于:
接下来讲解方法名中加selective和不加的区别:
insert方法不考虑插入的对象有的字段为空的情况,而insertSelective考虑了,只有字段不为空才进行插入操作。同理:
updateByPrimaryKeySelective在更新是只有更新的数据项的字段不为空时才进行更新操作。而updateByPrimaryKey对每一个字段都进行更新操作。
注意一些逆向工程生成的细节:
(1)Mybatis
逆向工程不区分大小写,只认下划线:
注意:数据库中字段名为"userName",实体对象属性名称为"username"。
5.添加控制层和服务层
添加之前先在StudentMapper接口前加注解,将该接口添加到spring容器中:
(1)添加服务层
@Service标记将StudentServiceImpl添加到spring容器中。
(2)控制层
6.编写配置文件连接数据库(注意:GeneratorMapper.xml只用于逆向工程生成类和xml文件,用完后还是要建立连接数据库的配置文件)
在pom.xml文件中加一个插件(用于将StudentMapper.xml文件在target文件夹中也生成):
7.运行主程序(主程序中的@SpringBootApplication注解不能少,它会使项目扫描所有使用的注解,所以注意所有的代码的文件或文件夹要在main程序所在的.java文件位于同一目录下)
浏览器中输入网址,回车显示结果:
与数据库中的数据一致。
8.@MapperScan注解
注意之前的项目每建立一个xxMapper.java文件就要加一次@Mapper注解,但也可以采用一种更简便的方式:
在main程序所在类加注解@MapperScan,其中basePackages的值指定mapper包路径,这样就会扫描该包下的所有xxMapper.java并将其添加到spring容器中。
9.也可以改变xxMapper.xml文件位置,然后在配置文件中说明即可。
10.springboot中添加事务
在方法前添加@Transactional注解
上述int a=10/0;报错,前面对数据库的操作回滚(数据库的值不改变)。
注意:只要是从浏览器发出的请求默认是get。