MyBatis03——SpringBoot整合MyBatis

article/2025/8/12 14:43:47

目录

一、springboot整合mybatis

二、搭建环境

1、引入jar包

2、配置文件

3、准备控制层、业务层、持久层

4、SQLMapper文件

​编辑

三、动态sql

四、分页

4.1逻辑分页

4.2物理分页

4.2.1引入分页插件在pom.xml

4.2.2使用分页插件

五、事务

编程式事务

声明式事务

六、多表关联映射

 结果集映射:

一对多映射 collection(一个班级有多少学生)

一对一 association

作业

1、自己创建一个新的项目,实现springboot和mybatis的整合(面试题)

2、动态sql相关的标签都有哪些?各自的作用是什么(面试题)

3、分页插件如何实现?(面试题)

4、如何实现一对多映射(先缓缓,放到最后,明天还会再讲一遍)


一、springboot整合mybatis

1、接收请求

2、接收数据

3、事务

4、(创建SqlSessionFactory,SqlSession,UserMapper,)调用方法

5、配置文件 application.yml application.properties (mybatis-config.xml )

二、搭建环境

1、引入jar包

<dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-web</artifactId>
</dependency>
<!--mybatis 提供的和boot整合的jar包-->
<dependency><groupId>org.mybatis.spring.boot</groupId><artifactId>mybatis-spring-boot-starter</artifactId><version>2.3.0</version>
</dependency>
​
<dependency><groupId>com.mysql</groupId><artifactId>mysql-connector-j</artifactId><scope>runtime</scope>
</dependency>
<dependency><groupId>org.projectlombok</groupId><artifactId>lombok</artifactId><optional>true</optional>
</dependency>

2、配置文件

<dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-web</artifactId>
</dependency>
<!--mybatis 提供的和boot整合的jar包-->
<dependency><groupId>org.mybatis.spring.boot</groupId><artifactId>mybatis-spring-boot-starter</artifactId><version>2.3.0</version>
</dependency>
​
<dependency><groupId>com.mysql</groupId><artifactId>mysql-connector-j</artifactId><scope>runtime</scope>
</dependency>
<dependency><groupId>org.projectlombok</groupId><artifactId>lombok</artifactId><optional>true</optional>
</dependency>

3、准备控制层、业务层、持久层

控制层 

@RestController
@RequestMapping("/grade")
public class GradeController {@Autowiredprivate GradeService gradeService;
​//搜索 动态查询@RequestMapping("search")public List<Grade> searchGrade(Grade grade){return gradeService.searchGrade(grade);}// 批量保存@RequestMapping("saveBatch")public int saveBatch(List<Grade> grades) {return gradeService.saveBatch(grades);}
}

业务层 

public interface GradeService {//搜索 动态查询List<Grade> searchGrade(Grade grade);// 批量保存int saveBatch(List<Grade> grades);
}

持久层 

@Mapper
public interface GradeMapper {//搜索 动态查询List<Grade> searchGrade(Grade grade);// 批量保存int saveBatch(List<Grade> grades);
}

4、SQLMapper文件

  • <if>标签必须有test判断双引号里面是否为true,为true则使用if字符串拼接,多个语句拼接要写and或or
  • 动态查询配合模糊查询此处用<where><if>标签实现动态查询、like concat('%',#{gradeName},'%')试实现模糊查询
<?xml version="1.0" encoding="UTF-8" ?>
<!DOCTYPE mapperPUBLIC "-//mybatis.org//DTD Mapper 3.0//EN""https://mybatis.org/dtd/mybatis-3-mapper.dtd">
<mapper namespace="com.hl.mybatis03.mapper.GradeMapper">
<!--    //搜索 动态查询-->
<!--    List<Grade> searchGrade(Grade grade);--><select id="searchGrade" resultType="Grade">select * from grade<where><if test="gradeName != null and gradeName !='' ">grade_name like concat('%',#{gradeName},'%')</if><if test="address != null and address !='' ">and address=#{address}</if></where></select>
<!--    // 批量保存-->
<!--    int saveBatch(List<Grade> grades);-->
</mapper>

三、动态sql

  • <where> 标签       添加where关键字,去除紧邻的 and 或者 or
  • <if> 标签               动态判断 test=""
  • <foreach>标签      循环 collection=“list” item="obj" index="index"——collection属性接收集                                    合、item指定集合中属性名、index指定索引下标的名字
  • <trim>标签            代替where和set
                                  prefix="where" prefixOverrides="and|or"
                                  ——prefix=“”是代替某个标签、prefixOverrides=“”是去除重复的                                                prefix="set" suffixOverrides=","
                                  ——suffixOverrides=“,”是去除最后的逗号
  • <set>标签             动态更新 去除最后的 ,
  • <choose> <when> <otherwise> case-when 选择一个条件执行

新增一般用@requestbody接收前端传来的json集合

//搜索 动态查询
@RequestMapping("search")
public List<Grade> searchGrade(Grade grade){return gradeService.searchGrade(grade);
}
// 批量保存
@RequestMapping("saveBatch")
public int saveBatch(@RequestBody List<Grade> grades) {return gradeService.saveBatch(grades);
}
@Mapper
public interface GradeMapper {//搜索 动态查询List<Grade> searchGrade(Grade grade);// 批量保存int saveBatch(@Param("list") List<Grade> grades);
}
<!--    //搜索 动态查询-->
<!--    List<Grade> searchGrade(Grade grade);--><select id="searchGrade" resultType="Grade">select * from grade<where><if test="gradeName != null and gradeName !='' ">grade_name like concat('%',#{gradeName},'%')</if><if test="address != null and address !='' ">and address=#{address}</if></where></select>
<!--    // 批量保存-->
<!--    int saveBatch(@Param("list")List<Grade> grades);--><insert id="saveBatch">insert into grade(grade_name,address)values<foreach collection="list" item="obj" separator=",">(#{obj.gradeName},#{obj.address})</foreach></insert>

四、分页

4.1逻辑分页

一次性从表中查询所有数据,在客户端分页。

4.2物理分页

每次从数据库表中查询指定条数的数据,返回给前端。

select * from grade limit 10; //第一页

select * from grade limit 11,10; //第二页

4.2.1引入分页插件在pom.xml

pageHelper-spring-boot-starter.jar

4.2.2使用分页插件

分页功能可以设置默认值        @RequestParam(defaultValue = "1")    防止前端没有传递参数

//搜索 动态查询+分页
@RequestMapping("search")
public PageInfo searchGrade(Grade grade,@RequestParam(defaultValue = "1") Integer pageNum,@RequestParam(defaultValue = "5") Integer pageSize){//开启分页插件 只能对紧邻的第一个sql语句进行分页PageHelper.startPage(pageNum,pageSize);//调用目标方法List<Grade> list = gradeService.searchGrade(grade);//封装分页对象PageInfo pageInfo = new PageInfo(list);return pageInfo;
}

http://localhost:8080/grade/search?pageNum=2&pageSize=3

select——查询满足条件的数据条数

Limit——查询前几条数据

五、事务

编程式事务

connnect.setAutoCommit(false);
connnect.startTransaction();
dml;
connection.commit();|| rollback();

声明式事务

@Transactional
在对应的类上或者方法上声明,即可使用事务。

六、多表关联映射

 结果集映射:

1、resultType :自动结果集映射 列名和属性名自动映射(相同或者满足驼峰式命名法)。

一般应用于单表操作。

2、resultMap: 手动结果集映射 手动的一个个指定列名和属性名的映射关系。

一般用于多表关联映射。

<!--结果集手动映射-->
<!--手动指令列名和属性名的映射关系  type="java中的数据类型,目标数据类型"-->
<resultMap id="baseMap" type="Grade"><!--主键字段映射--><id property="id" column="id"></id><!--非主键字段--><result property="gradeName" column="grade_name"></result><result property="address" column="address"></result>
</resultMap>
<select id="searchGrade" resultMap="baseMap">select * from grade<trim prefix="where" prefixOverrides="and |or"><if test="gradeName != null and gradeName !='' ">grade_name like concat('%',#{gradeName},'%')</if><if test="address != null and address !='' ">and address=#{address}</if></trim>
</select>

一对多映射 collection(一个班级有多少学生)

伪代码:

select grade.*,student.*
from grade join student
on grade.id = student.class_id
​
Grade{//一对多List<Student> list;
}
​
Student{//一对一Grade grade;
}

代码:

pojo包Student类

​​​​​​​@Data
@AllArgsConstructor
@NoArgsConstructor
public class Student {private Integer studentId;private String name;private Integer classId;
}

 pojo包Grade类

@Data
@NoArgsConstructor
@AllArgsConstructor
public class Grade {private int id;private String gradeName;private String address;//一对多关联private List<Student> list;
}

####

Sercvice接口

//一对多映射
public List<Grade> query();

 sql映射文件

映射的property是javabean定义的映射SQL的属性,column是SQL对应的列表名

<!--
//一对多映射
public List<Grade> query();
-->
<select id="query" resultMap="map2">select grade.id,grade.grade_name,grade.address,student.student_id,student.name,student.class_idfrom grade join studenton grade.id = student.class_id
</select>
<resultMap id="map2" type="Grade"><!--手动指定列名和属性名的映射关系--><!--主键--><id property="id" column="id"></id><!--非主键 普通属性--><result property="gradeName" column="grade_name"></result><result property="address" column="address"></result><!--集合属性 一对多映射 --><collection property="list" ofType="Student" autoMapping="true"><id column="student_id" property="studentId"></id></collection>
</resultMap>

一对一 association

作业

1、自己创建一个新的项目,实现springboot和mybatis的整合(面试题)

2、动态sql相关的标签都有哪些?各自的作用是什么(面试题)

场景核心标签关键点
批量新增<foreach> + <trim>遍历集合、处理逗号
动态查询<where> + <if> + <choose>条件分支、避免 WHERE AND 语法错误
动态修改<set> + <if>仅更新非空字段、去除末尾逗号
  • <where> 标签       添加where关键字,去除紧邻的 and 或者 or
  • <if> 标签               动态判断 test=""
  • <foreach>标签      循环 collection=“list” item="obj" index="index"——collection属性接收集                                    合、item指定集合中属性名、index指定索引下标的名字
  • <trim>标签            代替where和set
                                  prefix="where" prefixOverrides="and|or"
                                  ——prefix=“”是代替某个标签、prefixOverrides=“”是去除重复的                                                prefix="set" suffixOverrides=","
                                  ——suffixOverrides=“,”是去除最后的逗号
  • <set>标签             动态更新 去除最后的 ,
  • <choose> <when> <otherwise> case-when 选择一个条件执行

3、分页插件如何实现?(面试题)

见四、分页

4、如何实现一对多映射(先缓缓,放到最后,明天还会再讲一遍)


http://www.hkcw.cn/article/waiJsoPWQQ.shtml

相关文章

【linux】知识梳理

操作系统的分类 1. 桌⾯操作系统: Windows/macOS/Linux 2. 移动端操作系统: Android(安卓)/iOS(苹果) 3. 服务器操作系统: Linux/Windows Server 4. 嵌⼊式操作系统: Android(底层是 Linux) Liunx介绍 liunx系统:服务器端最常见的操作系统类型 发行版:Centos和Ubuntu 远程连接操…

计算机网络第1章(上):网络组成与三种交换方式全解析

目录 一、计算机网络的概念二、计算机网络的组成和功能2.1 计算机网络的组成2.2 计算机网络的功能 三、电路交换、报文交换、分组交换3.1 电路交换&#xff08;Circuit Switching&#xff09;3.2 报文交换&#xff08;Message Switching&#xff09;3.3 分组交换&#xff08;Pa…

经典面试题:一文了解常见的缓存问题

在面试过程中&#xff0c;面试官的桌子上摆放着很多高频的面试题&#xff0c;能否顺利回答决定了你面试通过的概率。其中缓存问题就是其中的一份&#xff0c;可以说掌握缓存问题及解决方法是面试前必须准备的内容。那么缓存有什么典型的问题&#xff0c;出现的原因是什么&#…

Python Turtle实战:打造高精度图形化秒表

&#x1f49d;&#x1f49d;&#x1f49d;欢迎莅临我的博客&#xff0c;很高兴能够在这里和您见面&#xff01;希望您在这里可以感受到一份轻松愉快的氛围&#xff0c;不仅可以获得有趣的内容和知识&#xff0c;也可以畅所欲言、分享您的想法和见解。 推荐&#xff1a;「storms…

Python实现P-PSO优化算法优化卷积神经网络CNN回归模型项目实战

说明&#xff1a;这是一个机器学习实战项目&#xff08;附带数据代码文档&#xff09;&#xff0c;如需数据代码文档可以直接到文章最后关注获取。 1.项目背景 随着人工智能和深度学习技术的快速发展&#xff0c;卷积神经网络&#xff08;CNN&#xff09;在图像分类、目标检测…

OVD开放词汇检测 Detic 训练COCO数据集实践

0、引言 纯视觉检测当前研究基本比较饱和&#xff0c;继续创新提升空间很小&#xff0c;除非在CNN和transformer上提出更强基础建模方式。和文本结合是当前的一大趋势&#xff0c;也是计算机视觉和自然语言处理结合的未来趋势&#xff0c;目前和文本结合的目标检测工作还是有很…

leetcode0404. 左叶子之和-easy

1 题目&#xff1a;左叶子之和 官方标定难度&#xff1a;易 给定二叉树的根节点 root &#xff0c;返回所有左叶子之和。 示例 1&#xff1a; 输入: root [3,9,20,null,null,15,7] 输出: 24 解释: 在这个二叉树中&#xff0c;有两个左叶子&#xff0c;分别是 9 和 15&#…

PINNs案例——二维磁场计算

基于物理信息的神经网络是一种解决偏微分方程计算问题的全新方法… 有关PINN基础详见&#xff1a;PINNs案例——中心热源温度场预测问题的torch代码 今日分享代码案例&#xff1a;二维带电流源磁场计算 该案例参考学习论文&#xff1a;[1]张宇娇&#xff0c;孙宏达&#xff0…

历年西安邮电大学计算机保研上机真题

历年西安邮电大学计算机保研上机真题 2025西安邮电大学计算机保研上机真题 2024西安邮电大学计算机保研上机真题 2023西安邮电大学计算机保研上机真题 在线测评链接&#xff1a;https://pgcode.cn/school 狗剩游泳 题目描述 酷暑难耐&#xff0c;好消息传来&#xff0c;毛…

【算法题】算法一本通

每周更新至完结&#xff0c;建议关注收藏点赞。 目录 待整理文章已整理的文章方法论数组与哈希表栈双指针&#xff08;滑动窗口、二分查找、链表&#xff09;树前缀树堆 优先队列&#xff08;区间/间隔问题、贪心 &#xff09;回溯图一维DP位操作数学与几何学二维DP随缘更新&a…

Spring如何实现组件扫描与@Component注解原理

Spring如何实现组件扫描与Component注解原理 注解配置与包扫描的实现机制一、概述&#xff1a;什么是注解配置与包扫描&#xff1f;二、处理流程概览三、注解定义ComponentScope 四、核心代码结构1. ClassPathScanningCandidateComponentProvider2. ClassPathBeanDefinitionSca…

NLP学习路线图(十六):N-gram模型

一、为何需要语言模型&#xff1f;概率视角下的语言本质 自然语言处理的核心挑战在于让机器“理解”人类语言。这种理解的一个关键方面是处理语言的歧义性、创造性和结构性。语言模型&#xff08;Language Model, LM&#xff09;为此提供了一种强大的数学框架&#xff1a;它赋…

使用ReactNative加载HarmonyOS Svga动画

这是一款使用ReactNative 加载HarmonyOS Svga动画的播放器插件 三端Svga动画统一使用点击这里 版本:v1.1.2 react-native-ohos-svgaplayer [!TIP] Github 地址 安装与使用 npm npm install react-native-ohos-svgaplayer yarn yarn add react-native-ohos-svgaplayer下面…

电路图识图基础知识-高、低压供配电系统一次系统识图(十一)

1、高、低压供配电 一 次系统的介绍 供配电系统中输送、分配和使用电能的电路&#xff0c;称为一次电路或一次回路&#xff0c;也称为一次系统或主接线。控制、指示、测量和保护一次电路及其中设备运行的电路&#xff0c;称为二次电路或二次回路.也称为二次系统。 工厂供配电系…

read-bridge开源程序是AI 增强阅读工具,使用 n+1 方法进行沉浸式语言学习。通过留在目标语言生态系统中学习语言,具有以流状态为中心的界面。

​一、软件介绍 文末提供程序和源码下载 read-bridge开源程序是AI 增强阅读工具&#xff0c;使用 n1 方法进行沉浸式语言学习。通过留在目标语言生态系统中学习语言&#xff0c;具有以流状态为中心的界面。 二、Overview 概述 此阅读助手支持源到源语言学习方法&#xff0c;减…

调教 DeepSeek - 输出精致的 HTML MARKDOWN

【序言】 不知道是不是我闲的蛋疼&#xff0c;对百度AI 和 DeepSeek 的回答都不太满意。 DeepSeek 回答句子的引用链接&#xff0c;始终无法准确定位。有时链接只是一个域名&#xff0c;有时它给的链接是搜索串如: baidu.com/?q"搜索内容"。 百度AI 回答句子的引用…

【论文阅读 | PR 2024 |ICAFusion:迭代交叉注意力引导的多光谱目标检测特征融合】

论文阅读 | PR 2024 |ICAFusion&#xff1a;迭代交叉注意力引导的多光谱目标检测特征融合 1.摘要&&引言2.方法2.1 架构2.2 双模态特征融合&#xff08;DMFF&#xff09;2.2.1 跨模态特征增强&#xff08;CFE&#xff09;2.2.2 空间特征压缩&#xff08;SFS&#xff09;…

本振相参解析(1)2025.6.1

前言 本振相参是射频与通信系统中的关键技术概念&#xff0c;涉及本机振荡器&#xff08;LO&#xff09;信号的相位稳定性和多信号间的相干性控制。以下从定义、关键技术、应用场景及挑战等方面展开分析&#xff1a; 一、核心概念解析 本振&#xff08;Local Oscillator, LO…

一个完整的日志收集方案:Elasticsearch + Logstash + Kibana+Filebeat (一)

整体链路 [应用服务器] --> [Filebeat] --> [Logstash] --> [Elasticsearch] --> [Kibana] 组件职责 Kibana&#xff1a; 可视化和分析日志数据Elasticsearch&#xff1a; 存储和索引日志数据Logstash&#xff1a; 解析、转换和丰富日志数据Filebeat&#xff1a…

Notepad++找回自动暂存的文件

场景&#xff1a; 当你没有保存就退出Notepad&#xff0c;下次进来Notepad会自动把你上次编辑的内容显示出来&#xff0c;以便你继续编辑。除非你手动关掉当前页面&#xff0c;这样Notepad就会删除掉自动保存的内容。 问题&#xff1a; Notepad会将自动保存的文件地址,打开Note…