基于SpringBoot的Mybatis和纯MyBatis项目搭建的区别

【由于之前学习MyBatis的时候是跟着视频敲的纯MyBatis项目,以至于在突然看到别人在SpringBoot项目里搭建MyBatis方式的时候很懵比...特此文字形式记录一下区别(应该还有好多种其他方式是我不知道的,主要应该就是要知道关键的流程步骤,其他的形式就算再多上手也很快了)】

目录

纯MyBatis项目

大致步骤

1、自己创建pojo表,添加数据

2、maven引入MyBatis坐标

3、在mybatis-config.xml中自己编写MyBatis核心配置文件:数据库连接信息、sql映射文件路径等

4、自己编写Mapper接口和sql映射文件:xxxMapper(接口,只定义方法)、xxxMapper.xml(sql映射文件,放在resources中,用来写具体的sql语句)

5、编写MyBatisDemo测试类 (手动加载mybatis的核心配置文件、获取 SqlSessionFactory、获取sqlSession对象用来执行sql、获取Mapper接口代理对象+执行sql、释放SqlSession)

【基本就是纯手工活儿】


基于SpringBoot的MyBatis搭建

先了解芝士

-- MBG :MBG(MyBatis Generator)是MyBatis官方提供的代码生

成工具,用于根据数据库表结构自动生成所需代码,包括:实体类、Mapper接口、Mapper映射文件xml、数据库表的CRUD代码。

大致步骤

0、maven中引入MyBatis相关依赖

1、配置MBG :配置generator.properties(定义数据库连接信息) → 配置generatorConfig.xml(是MBG的核心配置文件) → 运行Generator类(会自动生成文件夹来存放实体类、Mapper接口和sql映射文件)

2、application.yml中配置sql映射文件mapper.xml的位置

3、创建MyBatisConfig配置类配置mapper接口路径等

【解放双手了说是,而且配置MBG的具体代码也不需要自己写,网上找找就行】

区别

1、SpringBoot开发中,使用@Configuration配置类替代了传统的xml核心配置文件

2、SpringBoot中整合mybatis后,sql映射文件的位置由application.yml的mapper-locations来指定(没有xml核心配置文件,就不用在里面写了)

3、新旧mybatis配置对比:

:在xml配置文件中,<mappers>用于指定sql映射文件的位置,这样MyBatis就能找到该文件来映射SQL语句【需要同时配置接口和映射文件】

:在spring的Config配置类中,@MapperScan注解用于自动扫描Mapper接口,并为它们创建代理实现类,这样就不需要手动配置每个Mapper的sql映射文件了【spring更关注接口的扫描】

总结

1、传统的xml配置:直接管理MyBatis的XML和接口绑定

2、spring的@MapperScan:专注于让Spring管理Mapper接口的实例化,依赖MyBatis的默认约定或外部配置来定位XML

相关推荐
再睡一夏就好2 分钟前
【C++闯关笔记】使用红黑树简单模拟实现map与set
java·c语言·数据结构·c++·笔记·语法·1024程序员节
oak隔壁找我34 分钟前
ShardingJdbc配置说明
java·后端
javachen__1 小时前
Spring Boot将错误日志发送到企微微信或钉钉群
spring boot·后端·钉钉
升鲜宝供应链及收银系统源代码服务1 小时前
升鲜宝供应链管理系统-生鲜配送系统_分拣端界面重构设计(一)
spring boot·重构·开源·收银系统·生鲜门店·升鲜宝多门店收银系统
lzjava20241 小时前
Spring AI实现一个智能客服
java·人工智能·spring
Mos_x1 小时前
HeidiSQL导入与导出数据
java·后端
oak隔壁找我1 小时前
Elasticsearch QueryBuilders 高级使用案例
java·后端
青云交1 小时前
Java 大视界 -- Java 大数据在智能家居能源消耗模式分析与节能策略制定中的应用
java·大数据·智能家居·数据采集·能源消耗模式分析·节能策略制定·节能效果评估
Zhang青山2 小时前
【玩转全栈】----Django基本配置和介绍
java·后端
BUG?不,是彩蛋!2 小时前
Java Web 项目打包部署全解析:从 IDEA 配置到 Tomcat 运行
java·intellij-idea