栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 软件开发 > 后端开发 > Java

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

Java 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

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

步骤:
a.添加mybatis依赖,MySQL驱动
b.使用mybatis提供的逆向工程生成实体bean,映射文件,映射文件,DAO接口
1.新建springboot项目
先建立一个空项目

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

选择依赖:


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。

转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/490321.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号