Java 4.2 - MySQL

news2024/9/27 8:58:12

MySQL 基础

关系型数据库

关系型数据库就是建立在关系模型上的数据库。关系模型描述了实体属性以及实体和实体之间的关系。

在关系型数据库中,我们的数据都被存放在了各种表中(比如用户表),表中的每一行存放着一条数据。

常见的关系型数据库:MySQL、Oracle、SQL Server、SQLite

MySQL 简介

MySQL 是一种关系型数据库,可以持久化存储我们系统中的一些数据,例如用户数据。

MySQL 是开源免费且比较成熟的数据库,被应用在各种系统中。MySQL 的默认端口为 3306。

MySQL 基础架构

连接器:身份验证和权限相关

查询缓存:执行 select 语句时,先查询缓存(8.0后移除)

分析器:分析语法和词法

优化器:按照 MySQL 认为最优的方案去执行

执行器:执行语句

插件式存储引擎:MySQL 采用的是插件式架构,引擎包括 InnoDB、MyISAM、Memory 等多种存储引擎。

MySQL 存储引擎

MySQL 的核心存储是存储引擎

MySQL 支持哪些存储引擎?默认使用哪个?

支持 MyISAM、InnoDB。默认使用 InnoDB。

所有的存储引擎中只有 InnoDB 是支持事务的,它是唯一的事务性存储引擎。

MySQL 5.5.5 之前,MyISAM 是默认存储引擎。

MySQL 存储引擎架构了解吗?

MySQL 采用的是插件式架构,支持多种存储引擎,对于不同的表的特点还可以使用不同的存储引擎。存储引擎是基于表而不是数据库的。

我们也可以根据 MySQL 定义的存储引擎接口来编写一个属于自己的存储引擎。例如 InnoDB 本身是一个第三方的存储引擎,但因为它太过优秀,最后被 Oracle 收购成为 MySQL 默认的存储引擎了。

MyISAM 和 InnoDB 的区别是什么?

1、InnoDB 支持事务

2、InnoDB 支持行级锁

3、InnoDB 支持外键

4、InnoDB 支持数据库异常崩溃后的安全恢复

5、InnoDB 支持 MVCC

6、索引实现不一样:都是B+树,但是 InnoDB 数据文件本身就是索引文件。(数据和索引在物理上是存储在一起的)

MyISAM 和 InnoDB 如何选择?

因为我们非常关心崩溃后可以恢复这个事情,所以基本上无脑 InnoDB。

MySQL 查询缓存

查询缓存在 8.0 之后默认不开启,因为这个功能并不很实用。

查询缓存不命中的情况:

1、两个 select 任何字符不同

2、select 包含自定义函数、存储函数、用户变量、临时表、系统表

3、如果表发生变化

缓存虽然能够提升查询效率,但是同样带来了额外的开销,并且命中缓存的条件非常苛刻。

MySQL 事务

事务(数据库事务):一系列 SQL 操作,要么全部做,要么全部不做。

关系型数据库事务都存在 ACID 的特性:

1、A:atomic 原子性,一系列操作,要么全部都做,要么全都不做。

2、C:consistency 一致性,在事务前后数据库状态需保持一致。

3、I:Isolation 隔离性,在并发访问数据库的时候,一个用户的事务不会被其他事务干扰。

4、D:durability 持久性,一个事务被提交之后,它对数据库的改变是持久的

另提一句:实际上事务的特性应该是 AID,对于 C 一致性来说,它应该是事务满足 AID 这三个特性后,执行事务的结果。AID 是手段,而 C 是目的。

并发事务带来了哪些问题?

1、脏读:读到未提交的脏数据。

2、丢失修改:一个事务修改数据后,另外一个事务也修改了,这样第一个事务修改的结果丢失。

3、不可重复读:在一个事务中多次读,发现原来读的数据被修改,前后读取数据不一致。

4、幻读:在一个事务中读取了几行数据,随后的查询发现多了一些不存在的数据。

不可重复读和幻读有什么区别?

不可重复读的重点在于读取同一条数据发现结果不同

幻读的重点在于执行同一条 DQL 的时候,发现查到的记录增加了

它们的区别还在于解决它们的方案不同,幻读比不可重复读更难解决,而且幻读在某些情况下是可以接受的。

SQL 标准定义了哪些事务隔离级别?

1、读未提交:允许读取未提交的更改

2、读已提交:允许读取已经提交的更改

3、可重复读:同一事物内读取同一数据结果一致

4、可串行化:最高的隔离级别,完全服从 ACID 的隔离级别。所有的事务依次逐个执行。

MySQL 的隔离级别是怎么实现的?

InnoDB 默认的隔离级别是 可重复读。我们前面说,可重复不能解决幻读问题。

但实际上,InnoDB 实现的可重复读可以解决幻读问题,主要有以下两种情况:

1、快照读:由 MVCC 来保证不出现幻读

2、当前读:使用 Next-Key Lock 进行加锁来保证不出现幻读。

MySQL 锁

InnoDB 不仅支持表级锁,而且支持更细粒度的行级锁。

对比:

1、表级锁:MySQL 中锁粒度最大的一种,针对非索引字段加的锁。实现简单,消耗资源少,加锁快,不会出现死锁。但并发度比较低

2、行级锁:MySQL 中锁粒度最小的一种,针对索引字段加的锁。行级锁可以提高并发,减少数据库操作的冲突。但加速慢,代价高,可能出现死锁。

行级锁的使用有什么注意事项?

InnoDB 行锁针对索引字段,表锁针对非索引字段。当我们执行 update、delete语句的时候,如果没有命中唯一索引或者索引失效的时候,就会导致扫描全表并对表中所有行记录进行加锁!!请多多注意这一点。

共享锁和排他锁

共享锁也叫读锁(S锁):事务在读取记录的时候需要加共享锁,允许多个事务同时加共享锁。

排他锁也叫写锁(X锁):事务在修改记录的时候获取排他锁,不允许多个事务同时获取。如果一个记录被加了排他锁,那么不允许再加任何类型的锁。

意向锁的作用

意向共享锁(IS 锁):事务有意向对表中某些记录加 S 锁,加 S 锁前必须要获得该表的 IS 锁

意向排他锁(IX 锁):事务有意向对表中某些记录加 X 锁,加 X 锁前必须要获得该表的 IX 锁

意向锁是数据引擎自己维护的,不允许手动操作意向锁。

意向锁之间是相互兼容的

意向锁和共享锁和排他锁互斥(表级别的共享锁和排他锁,意向锁不会和行级锁互斥)

InnoDB 有哪几类行锁?

记录锁:单个行记录的锁

间隙锁:锁定一个范围,不包括当前记录

临键锁:上述两个锁的集合,包括记录本身

InnoDB 的默认隔离级别 RR,在当前读(一致性锁定读)中就使用的是 临键锁 来保证不出现幻读

当前读和快照读有什么区别?

快照读(一致性非锁定读)是单纯的 select 语句

快照即记录的历史版本,每行记录可能存在多个历史版本。

对于 RC 的情况下,我们读取被锁定行的最新一份快照。

对于 RR 的情况下,我们读取事务开始时的行快照。

当前读(一致性锁定读)就是给行记录加 X 锁 或者 S 锁。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/2067119.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

QCheckBox 全部取消选中

当我有很多 QCheckBox 被选中后&#xff0c;如何批量全部取消勾选呐&#xff1f; 方法一&#xff1a;findChildren函数方法二&#xff1a;foreach循环效果展示&#xff1a; 方法一&#xff1a;findChildren函数 // 遍历所有 QCheckBox 并取消选中QList<QCheckBox*> check…

新冠期间,Raspberry Pi 400 在肯尼亚为2500名学生提供在线学习机会

学生需要设备进行远程学习&#xff0c;Raspberry Pi 400为他们提供了在线学习的机会。 当疫情来袭时&#xff0c;接受前线重要岗位培训的护理和助产专业学生不得不改用远程教学来完成部分学业&#xff0c;但许多人家里没有设备&#xff0c;无法访问在线资料。Wisenet 伸出援手&…

全面解读AI大模型:一文带你看懂发展脉络与未来走向!

引言 近年来&#xff0c;随着深度学习技术的迅猛发展&#xff0c;AI大模型已经成为人工智能领域的重要研究方向和热点话题。AI大模型&#xff0c;指的是拥有巨大参数规模和强大学习能力的神经网络模型&#xff0c;如BERT、GPT等&#xff0c;这些模型在自然语言处理、计算机视觉…

小区物业维修管理系统/小区居民报修系统

摘要 小区物业维修是物业公司的核心&#xff0c;是必不可少的一个部分。在物业公司的整个服务行业中&#xff0c;业主担负着最重要的角色。为满足如今日益复杂的管理需求&#xff0c;各类小区物业维修管理系统也在不断改进。本课题所设计的小区物业维修管理系统&#xff0c;使用…

SD-WAN企业组网解决方案能解决企业的哪些问题?

SD-WAN企业组网解决方案在现代企业网络建设中具有重要意义&#xff0c;能够有效解决企业面临的多项挑战&#xff0c;下文将对此进行详细描述&#xff1a; 首先&#xff0c;SD-WAN技术在节省企业网络建设和运维成本方面表现突出。相比传统网络架构依赖大量专线和昂贵设备的方式&…

ACM模式下算法题输入输出攻略【C++】

文章目录 [TOC] 1. 核心代码模式与ACM模式1.1 ACM模式介绍1.2 注意事项 2. C常用的输入输出方法2.1 输入2.1.1 cin注意事项2.1.2 getline()注意事项2.1.3 getchar()注意事项 2.2 输出 3. 案例3.1 一维数组输入3.1.1 固定长度的一维数组3.1.2 不固定长度的一维数组 3.2 二维数组…

Java学习_19_方法引用及异常

文章目录 前言一、方法引用方法引用实例引用静态方法引用成员方法引用构造方法使用类名引用成员方法引用数组的构造方法综合练习 二、异常异常是什么异常的作用处理方案默认异常捕获异常 异常对象的常用方法抛出异常 总结 前言 博客仅记录个人学习进度和一些查缺补漏。 学习内…

使用ckplayer控制视频播放

目录 1、加载视频流 1.1、html模块 1.2、js模块 2、其他功能 2.1、缩放窗口 2.2、旋转窗口 2.3、卸载播放器 2.4、监听播放时间进度 2.5、定位播放 3、初始化属性说明 4、使用功能一览 ckplayer是一款在网页上播放视频的软件&#xff0c;基于javascript和css&#xf…

黑神话:悟空!爆了很多猴头! 借力,借智,借势(深度好文)——早读(逆天打工人爬取热门微信文章解读)

黑神话&#xff1a;悟空 怎么这么多猴头呢&#xff1f; 引言Python 代码第一篇 洞见 借力&#xff0c;借智&#xff0c;借势&#xff08;深度好文&#xff09;第二篇 股市风云结尾 引言 天哪 我昨天忘记发了 原因有二 一是比较忙 大家明白那种 3000块工资干2W的活的感觉吧 一开…

PyTorch使用------模型的定义和保存方法(带你讯速掌握构建线性回归,保存模型的方法!!!)

&#x1f43b; PyTorch使用合集&#xff1a; PyTorch使用------张量的创建和数值计算-CSDN博客 PyTorch使用------张量的类型转换&#xff0c;拼接操作&#xff0c;索引操作&#xff0c;形状操作-CSDN博客 目录 &#x1f354; 模型定义方法 &#x1f498; 使用PyTorch构建线性…

RISC-V vector(1) --- vector的引入与register说明

Vector相较于SIMD的优势 这两种实现方案&#xff0c;都是为了实现数据级并行性&#xff08;存在大量的数据可供程序同时计算&#xff09;&#xff1b; SIMD&#xff08;Single Instruction Multiple Data&#xff09; SIMD是将数据宽度和操作类型&#xff0c;都放在了指令中&a…

网络初识部分

1.网络 单机时代-局域网时代-广域网时代-移动互联网时代 局域网时代&#xff1a;通过路由器把几个电脑连接起来。 广域网时代&#xff1a;把更多的局域网连接到一起&#xff0c;构成的网络更庞大&#xff0c;可能已经覆盖了一个城市/国家/全世界。 2.什么是路由器&#xff…

关于武汉芯景科技有限公司的多协议收发芯片XJ526(第二篇RS422模式)开发指南(兼容SP526)

一、设置芯片为RS422模式 SP526 包含高度集成的串行收发器。SP526 提供 RS-232 &#xff08;V.28&#xff09;、RS-423 &#xff08;V.10&#xff09;、RS-422 &#xff08;V.11&#xff09; 和 RS-485 的硬件接口模式。接口模式选择通过两个控制引脚D0、D1完成。 我们将D0接…

【简历】25届青岛某一本JAVA简历:中厂不要强调算法,面试官听不懂

注&#xff1a;为保证用户信息安全&#xff0c;姓名和学校等信息已经进行同层次变更&#xff0c;内容部分细节也进行了部分隐藏 简历说明 今天我们要看的是一位来自25届青岛某一本硕士同学的Java简历。 依旧是先判断自己要投什么层次的厂&#xff0c;也就是我们校招第一法则…

Netty04-优化与源码

四. 优化与源码 1. 优化 1.1 扩展序列化算法 序列化&#xff0c;反序列化主要用在消息正文的转换上 序列化时&#xff0c;需要将 Java 对象变为要传输的数据&#xff08;可以是 byte[]&#xff0c;或 json 等&#xff0c;最终都需要变成 byte[]&#xff09;反序列化时&…

SQL进阶技巧:如何按任意时段分析时间区间问题? | 区间重叠问题应用

目录 0 场景描述 1 数据准备 2 问题分析 方法1:分情况讨论,找出重叠区间 方法2:暴力美学法。按区间展开成日期明细表 3 小结 0 场景描述 现有用户还款计划表 user_repayment ,该表内的一条数据,表示用户在指定日期区间内 [date_start, date_end] ,每天还款 repay…

成为顶尖1%前端开发者的10项必备技能

从你可能已经熟悉的前端基础开始&#xff1b;然后进入关键技能&#xff0c;如使用浏览器开发工具和利用AI快速编码。包括99%的开发者忽视的宝贵通用技能。 从你可能已经熟悉的前端基础开始&#xff1b;然后进入关键技能&#xff0c;如使用浏览器开发工具和利用AI快速编码。 包…

【youcans论文精读】KAN 2.0:面向科学的KAN网络

欢迎关注『youcans论文精读』系列 本专栏内容和资源同步到 GitHub/youcans 【youcans论文精读】KAN 2.0&#xff1a;面向科学的KAN网络 1. KAN2.0 简介1.1 KAN 2.0 论文发布1.2 KAN2.0 的新特点&#xff1a;1.3 KAN 回顾 2. MultiKAN&#xff1a;用乘法增强 KAN 网络的表达能力…

足底筋膜炎专用药

足底筋膜炎专用药“古顺*敷堂筋膜*贴”通过其独特的药效和用法&#xff0c;能够针对足底筋膜炎进行有效治疗&#xff0c;缓解患者疼痛和不适感&#xff0c;促进炎症消退和肌肉恢复。长时间站立、行走或进行高强度的跑步、跳跃等活动&#xff0c;会使足底筋膜受到持续的牵拉和压…

MEMS 传感器 4GDTU 说明书

本系统经过精心设计&#xff0c;可无缝对接三石峰的振动管理系统平台。通过该平台&#xff0c;用户可直观查看传感器数据、分析振动趋势、预警潜在故障&#xff0c;并依据分析结果制定针对性的维护策略&#xff0c;从而有效提升设备运行的可靠性与安全性。 本产品广泛应用于工…