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

步骤:
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。

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值