Spring Boot 2.x(四):整合Mybatis的四种方式
前言
目前的大环境下,使用Mybatis
作为持久层框架还是占了绝大多数的,下面我们来说一下使用Mybatis
的几种姿势。
姿势一:零配置注解开发
第一步:引入依赖
首先,我们需要在pom文件中添加依赖:
第二步:配置文件
这里我们采用yml来进行编写,与properties文件相比,yml看起来更加简洁优雅,这里需要注意的是driver-class-name
这个属性我们采用的是com.mysql.cj.jdbc.Driver
而非之前的com.mysql.jdbc.Driver
,如果采用之前包下的Driver
,控制台会打印出一行这样的信息告诉我们去用新的~
第三步:指定MapperScan
首先,我们需要在启动类指定@MapperScan
,这样做就可以不用去挨个的在Mapper
接口中添加@Mapper
注解。这里的值就是你的Mapper
接口所在的包的路径。
第四步:编写Mapper接口
通过@Select
注解和@Resuts
注解可以指定SQL语句以及返回值。当然,其他的不同的操作也有不同的注解,比如@Insert
、@Update
、@Delete
第五步:测试程序编写
访问 localhost:8081/user/findAll,我们就可以看到测试的结果:
姿势二:XML
我们用的最多的是这种方式,下面来看看怎么去实现,第一步与姿势一的重复,这里就不再多做阐述
第一步:编写配置文件
我们需要在配置文件中添加mybatis-config.xml
的路径以及用于Mapper*.xml
的文件的路径:
第二步:编写Mapper接口以及配置文件:
Mapper接口:
mybatis-config.xml:
UserMapper.xml:
这里需要注意UserMapper.xml中的namespace
需要与接口的路径一致,否则会出现错误。
测试:
测试的程序与之前的一致,我们直接访问localhost:8082/user/findAll
,可以看到成功的结果:
姿势三:SqlSession
使用SqlSession的姿势和可以与上面两种方式进行结合,emmm。。。可以这么理解,SQL就在那里,只不过分为了两个不同的方法去调用。其余的代码我们就不再多讲,直接来看是如何调用的:
可以看到,参数写的是要调用的方法的路径(这里是与namespace
相对应)。下面我们可以运行一下程序:
姿势四:基于SqlSession的升级
这里,我们基于SqlSession
进行了一次升级,首先我们写了一个BaseDao
,作为一个公用的接口。接口的实现是通过sqlSessionTemplate
。
然后我们将*Mapper.xml
的namespace
改为*Mapper
。现在,我们可以直接将所有的Mapper
接口删除,直接通过dao
进行调用~
然后我们来启动程序后去访问
关于Mybatis
的使用,我们就先讲到这里~
原创文章,文笔有限,才疏学浅,文中若有不正之处,万望告知。
源码可以去github或者码云上进行下载,后续的例子都会同步更新。
云撸猫
公众号
Spring Boot 2.x(四):整合Mybatis的四种方式的更多相关文章
- SpringBoot从入门到精通二(SpringBoot整合myBatis的两种方式)
前言 通过上一章的学习,我们已经对SpringBoot有简单的入门,接下来我们深入学习一下SpringBoot,我们知道任何一个网站的数据大多数都是动态的,也就是说数据是从数据库提取出来的,而非静态数 ...
- Spring Boot 定义系统启动任务,你会几种方式?
在 Servlet/Jsp 项目中,如果涉及到系统任务,例如在项目启动阶段要做一些数据初始化操作,这些操作有一个共同的特点,只在项目启动时进行,以后都不再执行,这里,容易想到web基础中的三大组件( ...
- [Spring] 学习Spring Boot之二:整合MyBatis并使用@Trasactional管理事务
一.配置及准备工作 1.在 Maven 的 pom 文件中新增以下依赖: <dependency> <groupId>mysql</groupId> <art ...
- Spring Boot 知识笔记(整合Mybatis)
一.pom.xml中添加相关依赖 <!-- 引入starter--> <dependency> <groupId>org.mybatis.spring.boot&l ...
- Spring Boot框架 - 数据访问 - 整合Mybatis
一.新建Spring Boot项目 注意:创建的时候勾选Mybatis依赖,pom文件如下 <dependency> <groupId>org.mybatis.spring.b ...
- spring boot(二)整合mybatis plus+ 分页插件 + 代码生成
先创建spring boot项目,不知道怎么创建项目的 可以看我上一篇文章 用到的环境 JDK8 .maven.lombok.mysql 5.7 swagger 是为了方便接口测试 一.Spring ...
- Spring Boot数据访问之整合Mybatis
在Mybatis整合Spring - 池塘里洗澡的鸭子 - 博客园 (cnblogs.com)中谈到了Spring和Mybatis整合需要整合的点在哪些方面,需要将Mybatis中数据库连接池等相关对 ...
- Spring Boot学习笔记(五)整合mybatis
pom文件里添加依赖 <!-- 数据库需要的依赖 --> <dependency> <groupId>org.mybatis.spring.boot</gro ...
- springboot整合mybatis的两种方式
https://blog.csdn.net/qq_32719003/article/details/72123917 springboot通过java bean集成通用mapper的两种方式 前言:公 ...
- 记录初学Spring boot中使用GraphQL编写API的几种方式
Spring boot+graphql 一.使用graphql-java-tools方式 <dependency> <groupId>com.graphql-java-kick ...
随机推荐
- hive求TopN语句
ROW_NUMBER,RANK(),DENSE_RANK() 先了解这三个之间的区别: Rank():1,2,2,4,5(一般用这个较多,不会影响总排名) Dense_rank():1,2,2,3,4 ...
- mysql练习
1.表关系 创建如下表格,并创建相关约束 ##(1)创建一个数据库 create database db2 default charset utf8; ##切换到db2数据库中 use db2 ##创 ...
- 20175324王陈峤宇 《Java程序设计》第六周学习总结
教材学习内容总结 第七章 一.内部类与外部类的关系 1.内部类可以使用外嵌类的成员变量和方法.2.类体中不可以声明类变量和类方法,外部类可以用内部类声明对象.3.内部类仅供外嵌类使用.4.类声明可以使 ...
- 了解vue APi
阳光那么好,何必自寻烦恼,过好每一个当下,一万个美丽的未来抵不过一个温暖的现在. 一.Vue.nextTick(): 该api 是在Dom节点更新结束之后执行的一个延时回调.在修改数据之后,立即使用这 ...
- Oracle报错ORA-12516 TNS:listener could not find available handler with matching protocol stack
解决办法定位原因-- 以sysdba身份登陆PL/SQL sqlplus / as sysdba;-- 查看当前连接进程数SQL>select count(*) from v$process;- ...
- Jmeter中连接Oracle报错Cannot create PoolableConnectionFactory
填坑贴,之前一直用jmeter2.13版本进行oracle测试,今天改为3.2版本,发现按照以往的方法执行测试,JDBC Request结果始终报错:Cannot create PoolableCon ...
- C# INI文件读写类
public class Ini { // 声明INI文件的写操作函数 WritePrivateProfileString() [System.Runtime.InteropServices.DllI ...
- ubuntu 修改系统时间无效
用root用户修改服务器时间无效:使用hwclock -w也不行 解决方法: 需要取消自动从互联网同步时间才可以的 timedatectl set-ntp 0 上面的命令可以关闭自动同步,然后你再设置 ...
- 干货分享: 长达250页的Libvirt Qemu KVM的ppt,不实验无真相
下载地址:Libvirt Qemu KVM 教程大全 http://files.cnblogs.com/popsuper1982/LibvirtQemuKVM.pptx 1. 概论 1.1 虚拟化的基 ...
- 255.Spring Boot+Spring Security:使用md5加密
说明 (1)JDK版本:1.8 (2)Spring Boot 2.0.6 (3)Spring Security 5.0.9 (4)Spring Data JPA 2.0.11.RELEASE (5)h ...