第十五篇:Mybatis
文章目录
- 一、什么是MyBatis
- 二、Mybatis入门案例
- 三、配置SQL提示
- 四、数据库连接池
- 四、lombok
- 五、mybatis基础操作
- 5.1 根据id删除
- 5.2 预编译SQL
- 5.3 新增员工
- 5.4 更新员工
- 5.5 查询员工(用于页面回显)
- 5.6 条件查询
- 七、XML映射文件
- 八、动态SQL
- 8.1 if语句
- 8.2 foreach语句
- 8.3 sql/include语句
- 小结
一、什么是MyBatis
MyBatis是一款优秀的持久层框架,用于简化JDBC的开发
二、Mybatis入门案例
使用MyBatis查询所有用户的数据
三、配置SQL提示
四、数据库连接池
数据库连接池是个容器,负责分配,管理数据库连接(Connection)
它允许应用程序重复使用一个现有的数据库连接,而不是在重新建立一个
释放空间时间超过最大空闲时间的连接,来避免因为没有释放连接而引起的数据库连接遗漏
- 如果没有连接池,每次访问数据库时候,需要开启一个新的连接,用完需要关闭,比较浪费资源
- 有了数据库连接池,程序在初始化的时候,会在这个容器中创建一定量的连接对象,后面客户端在访问数据库时候,会在连接池中来获取连接,用完之后再归还,就可以做到连接的复用,而不用每次都新建一个在关闭
数据库连接池的优势:
- 资源重用
- 提升系统响应速度
- 避免数据库连接遗漏
标准接口:DataSource
- 官方提供的数据库连接池接口,由第三方组织实现此接口
- 功能:获取连接
Connection getConnection() throws SQLException;
Springboot默认Hikari(追光者)
Druid(德鲁伊):
- Druid连接池是阿里巴巴开源的数据库连接池项目
- 功能强大,性能优秀,是Java语言最好的数据库连接池之一
四、lombok
lombok是一个使用的Java类库,能够通过注解的形式自动生成构造器,getter/setter,equals,hashcode,tostring等方法,并可以自动化生成日志变量,简化Java开发,提高效率
注解 | 作用 |
---|---|
@Getter/Setter | 为所有的属性提供get/set方法 |
@ToString | 给雷自动生成toString方法。 |
@EqualsAndHashCode | 根据类所拥有的非静态字段自动重写equals方法和hashCode方法 |
@Data | 注解在类,生成setter/getter、equals、canEqual、hashCode、toString方法,如为final属性,则不会为该属性生成setter方法。 |
@NoArgsConstructor | 生成无参的构造方法。 |
@AllArgsConstructor | 生成包含类中所有字段的构造方法。 |
需要在pom.xml中加入lombok依赖
五、mybatis基础操作
准备工作
- 准备数据表emp
- 创建一个新的springboot工程,引入起步依赖(mybatis,mysql驱动,lombok)
- 配置文件中引入数据库的连接信息
- 创建Emp实体类(采用驼峰命名法)
- 准备Mapper接口EmpMapper
5.1 根据id删除
在mapper接口中写入代码如下:
@Mapper
public interface EmpMapper {
// 根据id删除@Delete("delete from mybatis.emp where id = #{id}")public void delect(Integer id);
}
在测试类中调用如下:
@SpringBootTest //整合单元测试的类
class SpringbootMybatisApplicationTests {@Autowiredprivate EmpMapper empMapper;@Testpublic void test(){int delete = empMapper.delect(17);System.out.println(delect)}
}
返回值为1(受影响的行数):
5.2 预编译SQL
性能更高
更安全(防止SQL注入)
只需要编译一次,后面直接把参数传进去就可以执行,所以性能更高,
5.3 新增员工
在mapper接口中写入代码如下:
// 新增员工@Insert("insert mybatis.emp(username, name, gender, image, job, entrydate, dept_id, create_time, update_time) " +"values (#{username},#{name},#{gender},#{image},#{job},#{entrydate},#{deptId},#{createTime},#{updateTime})")public void insert(Emp emp);
在测试类中测试如下:
useGeneratedKeys:是否要获取到返回来的数据
keyProperty:返回来的数据往那个地方封装
5.4 更新员工
在mapper接口中写入代码如下:
// 更新员工@Update("update mybatis.emp set username = #{username},name = #{name},gender = #{gender},image = #{image}" +",job = #{job},entrydate = #{entrydate},dept_id = #{dept_id},create_time = #{createTime},update_time = #{updateTime}")public void update(Emp emp);
在测试类中测试如下:
5.5 查询员工(用于页面回显)
在mapper接口中写入代码如下:
// 根据id查询员工@Select("select * from mybatis.emp where id = #{}")public Emp getById(Integer id);
在测试类中测试如下:
运行结果如下:
但是运行结果中,其中dept_id,creat_time,update_time 并没有结果
原因是因为没有进行数据封装
开启mybatis自动映射开关
在application配置文件中
5.6 条件查询
// 条件查询员工@Select("select * from mybatis.emp where name like concat('%','#{name}','%') and gender = #{gender} and" +" entrydate between #{begin} and #{end} order by update_time desc " )public List<Emp> list(String name , Short gender , LocalDate begin , LocalDate end);
运行结果
七、XML映射文件
规范:
- XML映射文件的名称与Mapper接口名称保持一致,并且将XML映射文件和Mapper接口放置在相同包下(同包同名)
- XML映射文件的namespace属性为Mapper接口全限定名一致
- XML映射文件中sql语句的id与Mapper接口中的方法名一致,并保持返回类型一致
以xml定义sql语句例如:
先加上xml约束
<?xml version="1.0" encoding="UTF-8" ?>
<!DOCTYPE mapperPUBLIC "-//mybatis.org//DTD Mapper 3.0//EN""http://mybatis.org/dtd/mybatis-3-mapper.dtd"><!-- nampespace 绑定Mapper接口的全名-->
<mapper namespace="com.itzhangxx.mapper.EmpMapper"><!-- 条件查询员工--><select id="list" resultType="com.itzhangxx.Pojo.Emp">select * from mybatis.emp where name like concat('%','#{name}','%') and gender = #{gender} andentrydate between #{begin} and #{end} order by update_time desc</select>
</mapper>
八、动态SQL
8.1 if语句
随着用户的输入或外部条件的变化而变化的SQL语句,称为动态SQL
<mapper namespace="com.itzhangxx.mapper.EmpMapper"><!-- 条件查询员工--><select id="list" resultType="com.itzhangxx.Pojo.Emp">select *from mybatis.emp<where><if test="name != null">name like concat('%', '#{name}', '%')</if><if test="gender != null">and gender = #{gender}</if><if test="begin != null and end != null">and entrydate between #{begin} and #{end}</if><where>order by update_time desc</select>
</mapper>
这样就可以动态的满足需求的再进行SQL的查找
优化上面更新员工代码:
原SQL:
@Update("update mybatis.emp set username = #{username},name = #{name},gender = #{gender},image = #{image}" +",job = #{job},entrydate = #{entrydate},dept_id = #{dept_id},create_time = #{createTime},update_time = #{updateTime}")public void update(Emp emp);
改造后如下
<update id="update2">update mybatis.emp<set><if test="username != null">username = #{username},</if><if test="name != null">name = #{name},</if><if test="gender != null">gender = #{gender},</if><if test="image != null">image = #{image},</if><if test="job != null">job = #{job},</if><if test="entrydate != null">entrydate = #{entrydate},</if><if test="deptId != null">dept_id = #{dept_id},</if><if test="updateTime != null">update_time = #{updateTime},</if> </set></update>
- <if>:用于判断条件是否成立,使用test属性进行条件判断,如果条件为true,则拼接SQL
- <where>:只用于在子元素有内容的情况下才插入where子句,而且会自动取出子句的开头的AND 或 OR
- <set>:动态的在行首插入set关键字,会删除额外的逗号(用于update中)
8.2 foreach语句
如果想要删除多个员工数据的话,就可以使用foreach语句进行遍历
例如:
<delete id="deleteById">delete from mybatis.emp where id in<foreach collection="ids" item="id" open="(" separator="," close=")">#{id}</foreach></delete>
测试如下:传入11,12,13,14
@Testpublic void testDeleteById(){List<Integer> ids = Arrays.asList(11,12,13,14);empMapper.deleteById(ids);return ;}
然后实际执行的sql语句如下:
delete from mybatis.emp where id in(11,12,13,14)
属性 | 含义 |
---|---|
collection | 要遍历的集合 |
item | 遍历出来的元素 |
separator | 分隔符 |
open | 遍历开始前拼接的片段 |
close | 遍历结束后的拼接的片段 |
8.3 sql/include语句
在查找中不建议使用select * ,会降低代码效率,但是输入全部字段的话,也会有大量重复的,所以 使用<sql>定义相同的SQL,并且设定唯一标识,使用<include>调用这个唯一标识即可
实现效果如下:
<sql id="selectAll">select id, username, password, name, gender, image, job, entrydate, dept_id, create_time, update_timefrom mybatis.emp</sql><!-- 条件查询员工--><select id="list" resultType="com.itzhangxx.Pojo.Emp"><include refid="selectAll"></include><where><if test="name != null">name like concat('%', '#{name}', '%')</if><if test="gender != null">and gender = #{gender}</if><if test="begin != null and end != null">and entrydate between #{begin} and #{end}</if></where>order by update_time desc</select>
重点规范:
- XML映射文件的名称与Mapper接口名称保持一致,并且将XML映射文件和Mapper接口放置在相同包下(同包同名)
- XML映射文件的namespace属性为Mapper接口全限定名一致
- XML映射文件中sql语句的id与Mapper接口中的方法名一致,并保持返回类型一致
语句 | 含义 |
---|---|
<if> | 用于判断条件是否成立,使用test属性进行条件判断,如果条件为true,则拼接SQL |
<where> | 只用于在子元素有内容的情况下才插入where子句,而且会自动取出子句的开头的AND 或 OR |
<set> | 动态的在行首插入set关键字,会删除额外的逗号(用于update中) |
<foreach> | 按照规范进行遍历 |
<sql> | 使用<sql>定义相同的SQL,并且设定唯一标识 |
<include> | 使用中按照唯一标识进行调用定义的SQL |
小结
写本文主要是为了分享我的学习过程,也是给自己记个笔记,哪里忘记了,回来再看一眼,也可以很快的回想起来
相关文章:

第十五篇:Mybatis
文章目录 一、什么是MyBatis二、Mybatis入门案例三、配置SQL提示四、数据库连接池四、lombok五、mybatis基础操作5.1 根据id删除5.2 预编译SQL5.3 新增员工5.4 更新员工5.5 查询员工(用于页面回显)5.6 条件查询 七、XML映射文件八、动态SQL8.1 if语句8.2…...

【MacBook系统homebrew镜像记录】
安装 使用Homebrew 国内源安装脚本,贼方便: /bin/zsh -c "$(curl -fsSL https://gitee.com/cunkai/HomebrewCN/raw/master/Homebrew.sh)"切换至清华大学镜像源: 命令合并: 分别切换了 brew.git、 homebrew-core.git、 homebrew-…...

深拷贝总结
JSON.parse(JSON.stringify(obj)) 这行代码的运行过程,就是利用 JSON.stringify 将js对象序列化(JSON字符串),再使用JSON.parse来反序列化(还原)js对象;序列化的作用是存储和传输。(…...

RabbitMQ在云原生环境中部署和应用实践
一、RabbitMQ和云原生技术的关系 RabbitMQ是一种开源的、实现了先进的消息队列协议(AMQP)的消息队列软件。而云原生技术就是为在公共云、私有云以及其他各种云环境提供应用的一种方法。RabbitMQ和云原生技术在分布式系统和微服务架构中都起到了关键作用…...

flask 后端 + 微信小程序和网页两种前端:调用硬件(相机和录音)和上传至服务器
选择 flask 作为后端,因为后续还需要深度学习模型,python 语言最适配;而 flask 框架轻、学习成本低,所以选 flask 作为后端框架。 微信小程序封装了调用手机硬件的 api,通过它来调用手机的摄像头、录音机,…...

蓝桥杯嵌入式(G431)备赛笔记——ADC+LCD
目录 题目要求(真题): cubeMX配置: 小试牛刀: Keil代码: 效果演示: 题目要求(真题): 使用第十一届第二场真题,练习ADC波部分的代码 cubeMX配…...

最近公共祖先(LCA)
题目描述 如题,给定一棵有根多叉树,请求出指定两个点直接最近的公共祖先。 输入格式 第一行包含三个正整数 N,M,S,分别表示树的结点个数、询问的个数和树根结点的序号。 接下来 N−1 行每行包含两个正整数x,y,表示 x 结点和 y 结点之间有一条直接连接的边(数据保证可以…...

ABBYY FineReader15免费电脑OCR图片文字识别软件
产品介绍:ABBYY FineReader 15 OCR图片文字识别软件 ABBYY FineReader 15是一款光学字符识别(OCR)软件,专门设计用于将扫描的文档、图像和照片中的文本转换成可编辑和可搜索的格式。这款软件利用先进的OCR技术,能够识别…...

2024年第十七届 认证杯 网络挑战赛 (A题)| 保暖纤维的保暖能力 |数学建模完整代码+建模过程全解全析
当大家面临着复杂的数学建模问题时,你是否曾经感到茫然无措?作为2022年美国大学生数学建模比赛的O奖得主,我为大家提供了一套优秀的解题思路,让你轻松应对各种难题。 让我们来看看认证杯 网络挑战赛 (A题)!…...

算法训练营第37天|LeetCode 738.单调递增的数字 968.监控二叉树
LeetCode 738.单调递增的数字 题目链接: LeetCode 738.单调递增的数字 解题思路: 从后向前遍历,当不满足递增条件时,当前位置赋值为9,前一位减一。之后记录不满足位置,将后续全部赋值为9. 代码&#x…...

Vue+el-table 修改表格 单元格横线边框颜色及表格空数据时边框颜色
需求 目前 找到对应的css样式进行修改 修改后 css样式 >>>.el-table th.el-table__cell.is-leaf {border-bottom: 1px solid #444B5F !important;}>>>.el-table td.el-table__cell,.el-table th.el-table__cell.is-leaf {border-bottom: 1px solid #444B5F …...

大恒相机-程序异常退出后显示被占用
心跳时间代表多久向相机发送一次心跳包,如果超时则设备会认为断开了,停止工作并主动释放占用资源。 在相机打开后添加代码: #ifdef _DEBUG//设置心跳超时时间 3sObjFeatureControlPtr->GetIntFeature("GevHeartbeatTimeout")-&…...

头歌-机器学习 第16次实验 EM算法
第1关:极大似然估计 任务描述 本关任务:根据本节课所学知识完成本关所设置的选择题。 相关知识 为了完成本关任务,你需要掌握: 什么是极大似然估计; 极大似然估计的原理; 极大似然估计的计算方法。 什么是极大似然估计 没有接触过或者没有听过”极大似然估计“的同学…...

电脑启动引导的两种方式
电脑启动引导的两种方式 电脑启动引导有两种方式:Legacy 传统模式 和 UEFI 新型模式。 一、Legacy:指 主板的 传统的 BIOS 传输模式引导启动加载操作系统。 1.只支持 MBR 分区表,支持 32位和64位操作系统(如:winXP&…...

用php编写网站源码的一些经验
一、var_dump()函数 var_dump()函数在有页面跳转的情况下会看不到信息。因为 var_dump()函数输出信息默认显示到本页面。因此要看到var_dump()函数的输出,在有页面跳转时,需要将页面跳转改成显示本页面。 放在var_dump()函数里的变量如果是空值&#x…...

海山数据库(He3DB)原理剖析:浅析OLAP数据库计算引擎中的统计信息
背景: 统计信息在计算引擎的优化器模块中经常被提及,尤其是在基于成本成本优化(CBO)框架中统计信息发挥着至关重要的作用。CBO旨在通过评估执行查询的可能方法,并选择最有效的执行计划来提高查询性能。而统计信息则提…...

视频图像的两种表示方式YUV与RGB(4)
本篇主要讲YUV与RGB之间的转换,包括YUV444 颜色编码格式 转为 RGB 格式 ,RGB颜色编码格式转为 YUV444 格式。 一、 YUV与RGB之间的转换 YUV与RGB颜色格式之间进行转换时 , 涉及一系列的数学运算 ; YUV 颜色编码格式转为RGB格式的转换公式 取决于 于 YUV …...

PostgreSQL入门到实战-第十四弹
PostgreSQL入门到实战 PostgreSQL数据过滤(七)官网地址PostgreSQL概述PostgreSQL中BETWEEN 命令理论PostgreSQL中BETWEEN 命令实战更新计划 PostgreSQL数据过滤(七) BETWEEN运算符允许您检查值是否在值的范围内。 官网地址 声明: 由于操作系统, 版本更新等原因, 文章所列内容…...

分布式数据库中间件 Mycat 和 ShardingSphere 对比
Mycat 和 ShardingSphere 都是流行的分布式数据库中间件,都可以用于实现数据分片、读写分离和分布式事务等功能,但它们在设计理念、特点和功能实现上有一些区别 1. 设计理念: Mycat: 基于 MySQL 协议的代理式架构,主要…...

Python实现BOA蝴蝶优化算法优化BP神经网络回归模型(BP神经网络回归算法)项目实战
说明:这是一个机器学习实战项目(附带数据代码文档视频讲解),如需数据代码文档视频讲解可以直接到文章最后获取。 1.项目背景 蝴蝶优化算法(butterfly optimization algorithm, BOA)是Arora 等人于2019年提出的一种元启发式智能算…...

3D Web轻量化引擎HOOPS Commuicator如何从整体装配中创建破碎的装配零件和XML?
前言 虽然可以从某些本机CAD格式(其子组件驻留在单独的文件中,例如CATIA V5、Creo - Pro/E、NX或SolidWorks)创建破碎装配,但无法从整体装配文件(例如IFC、Revit)创建或3DXML。 本文介绍了一个示例&#…...

关于运行阿里云直播Demo pub get 报的错
flutter --version dart --version 如何使用Flutter框架推流_音视频终端 SDK(Apsara Video SDK)-阿里云帮助中心 终端输入 dart pub --trace get --no-precompile 打印详细报错信息 详细咨询chatgpt pub.dev 中已经是最新版本了 项目中已经是最新版本了 最终定位到 终端…...

C语言调用Python
目录 1.直接调用python语句 头文件引用 2.调用无参有参函数 1、调用无参函数 1.建立nopara.py文件 2.使用c语言根据上面流程进行调用 2、调用有参函数 1.建立nopara.py文件 2.使用c语言根据上面流程进行调用 C语言调用python需要我们已经安装好了libpython3的 dev依赖…...

SVN客户端异常问题处理
1、如遇svn服务端异常(所有用户登录不上) (1)登录192.168.**.**服务器,找到E:\仓库所在盘\VisualSVN-GlobalWinAuthz.ini (2)先备份VisualSVN-GlobalWinAuthz.ini文件 (3…...

gin+sse实现离散的消息通知
虽然网上的都是用sse实现将实时消息流不间断的推给前端,但是sse也可以模拟websocket进行突发的消息通知,而不是一直读取数据并返回数据。即服务端保存所有的连接对象,前端管理界面发送正常的http请求,在后端遍历所有的连接对象&am…...

C++ //练习 11.38 用unordered_map重写单词计数程序(参见11.1节,第375页)和单词转换程序(参见11.3.6节,第391页)。
C Primer(第5版) 练习 11.38 练习 11.38 用unordered_map重写单词计数程序(参见11.1节,第375页)和单词转换程序(参见11.3.6节,第391页)。 环境:Linux Ubuntu࿰…...

【示例】MySQL-4类SQL语言-DDL-DML-DQL-DCL
前言 本文主要讲述MySQL中4中SQL语言的使用及各自特点。 SQL语言总共分四类:DDL、DML、DQL、DCL。 SQL-DDL | Data Definition Language 数据定义语言:用来定义/更改数据库对象(数据库、表、字段) 用途 | 操作数据库 # 查询所…...

基于SpringBoot+Vue的果蔬种植销售一体化服务平台(源码+文档+部署+讲解)
一.系统概述 伴随着我国社会的发展,人民生活质量日益提高。于是对果蔬种植销售一体化服务管理进行规范而严格是十分有必要的,所以许许多多的信息管理系统应运而生。此时单靠人力应对这些事务就显得有些力不从心了。所以本论文将设计一套果蔬种植销售一体…...

数据结构面试
当然可以!以下是数据结构面试问题及答案整理: **什么是数据结构?** 答:数据结构是指组织和存储数据的方式,它允许高效地访问和操作数据。不同的数据结构有不同的优势和适用场景。常见的基本数据结构包括数组、链表、…...

Linux 上安装 SQLite
SQLite Download Page 从上面的链接中源代码区下载 sqlite-autoconf-*.tar.gz。 历史版本见下连接: https://sqlite.org/chronology.html...