MySQL—存储引擎(下)

2023-11-08

♥️作者:小刘在C站

♥️个人主页:小刘主页

♥️每天分享云计算网络运维课堂笔记,努力不一定有回报,但一定会有收获加油!一起努力,共赴美好人生!

♥️树高千尺,落叶归根人生不易,人间真情

前言

上一章讲了存储引擎,本章继续,从特点开始

目录

MySQL

1.存储引擎特点

1.1InnoDB

1). 介绍

2). 特点

3). 文件

 4). 逻辑存储结构

1). 介绍

2). 特点

3). 文件

1). 介绍

2). 特点

3).文件

面试题:

2 存储引擎选择


MySQL

MySQL是一个关系型数据库管理系统由瑞典MySQL AB 公司开发,属于 Oracle 旗下产品。MySQL 是最流行的关系型数据库管理系统之一,在 WEB 应用方面,MySQL是最好的 RDBMS (Relational Database Management System,关系数据库管理系统) 应用软件之一。

MySQL是一种关系型数据库管理系统,关系数据库将数据保存在不同的表中,而不是将所有数据放在一个大仓库内,这样就增加了速度并提高了灵活性。

MySQL所使用的 SQL 语言是用于访问数据库的最常用标准化语言。MySQL 软件采用了双授权政策,分为社区版和商业版,由于其体积小、速度快、总体拥有成本低,尤其是开放源码这一特点,一般中小型和大型网站的开发都选择 MySQL 作为网站数据库

1.存储引擎特点

上面我们介绍了什么是存储引擎,以及如何在建表时如何指定存储引擎,接下来我们就来介绍下来上面 重点提到的三种存储引擎 InnoDB MyISAM Memory 的特点。

1.1InnoDB

1). 介绍

InnoDB 是一种兼顾高可靠性和高性能的通用存储引擎,在 MySQL 5.5 之后, InnoDB 是默认的
MySQL 存储引擎。

2). 特点

DML 操作遵循 ACID 模型,支持事务;行级锁,提高并发访问性能;支持外键 FOREIGN KEY 约束,保证数据的完整性和正确性;

3). 文件

xxx.ibd xxx 代表的是表名, innoDB 引擎的每张表都会对应这样一个表空间文件,存储该表的表结
构( frm- 早期的 、 sdi- 新版的)、数据和索引。
参数: innodb_file_per_table
show variables like 'innodb_file_per_table';

如果该参数开启,代表对于 InnoDB 引擎的表,每一张表都对应一个 ibd 文件。 我们直接打开 MySQL 的数据存放目录: C:\ProgramData\MySQL\MySQL Server 8.0\Data , 这个目录下有很多文件 夹,不同的文件夹代表不同的数据库,我们直接打开 itcast 文件夹。

 

可以看到里面有很多的 ibd 文件,每一个 ibd 文件就对应一张表,比如:我们有一张表 account ,就
有这样的一个 account.ibd 文件,而在这个 ibd 文件中不仅存放表结构、数据,还会存放该表对应的
索引信息。 而该文件是基于二进制存储的,不能直接基于记事本打开,我们可以使用 mysql 提供的一个指令 ibd2sdi ,通过该指令就可以从 ibd 文件中提取 sdi 信息,而 sdi 数据字典信息中就包含该表
show variables like 'innodb_file_per_table' ;
1 的表结构。

 4). 逻辑存储结构

 

表空间 : InnoDB 存储引擎逻辑结构的最高层, ibd 文件其实就是表空间文件,在表空间中可以
包含多个 Segment 段。
: 表空间是由各个段组成的, 常见的段有数据段、索引段、回滚段等。 InnoDB 中对于段的管
理,都是引擎自身完成,不需要人为对其控制,一个段中包含多个区。
: 区是表空间的单元结构,每个区的大小为 1M 。 默认情况下, InnoDB 存储引擎页大小为
16K , 即一个区中一共有 64 个连续的页。
: 页是组成区的最小单元, 页也是 InnoDB 存储引擎磁盘管理的最小单元 ,每个页的大小默
认为 16KB 。为了保证页的连续性, InnoDB 存储引擎每次从磁盘申请 4-5 个区。
: InnoDB 存储引擎是面向行的,也就是说数据是按行进行存放的,在每一行中除了定义表时
所指定的字段以外,还包含两个隐藏字段 ( 后面会详细介绍 )
1.2 MyISAM

1). 介绍

MyISAM MySQL 早期的默认存储引擎。

2). 特点

不支持事务,不支持外键
支持表锁,不支持行锁
访问速度快

3). 文件

xxx.sdi :存储表结构信息
xxx.MYD: 存储数据
xxx.MYI: 存储索引

 

1.3 Memory

1). 介绍

Memory 引擎的表数据时存储在内存中的,由于受到硬件问题、或断电问题的影响,只能将这些表作为临时表或缓存使用。

2). 特点

内存存放
hash 索引(默认)

3).文件

xxx.sdi :存储表结构信息
 

 

面试题:

InnoDB 引擎与 MyISAM 引擎的区别 ?
. InnoDB 引擎 , 支持事务 , MyISAM 不支持。
. InnoDB 引擎 , 支持行锁和表锁 , MyISAM 仅支持表锁 , 不支持行锁。
. InnoDB 引擎 , 支持外键 , MyISAM 是不支持的。

2 存储引擎选择

在选择存储引擎时,应该根据应用系统的特点选择合适的存储引擎。对于复杂的应用系统,还可以根据
实际情况选择多种存储引擎进行组合。
InnoDB: Mysql 的默认存储引擎,支持事务、外键。如果应用对事务的完整性有比较高的要
求,在并发条件下要求数据的一致性,数据操作除了插入和查询之外,还包含很多的更新、删除操
作,那么 InnoDB 存储引擎是比较合适的选择。
MyISAM : 如果应用是以读操作和插入操作为主,只有很少的更新和删除操作,并且对事务的完
整性、并发性要求不是很高,那么选择这个存储引擎是非常合适的。
MEMORY :将所有数据保存在内存中,访问速度快,通常用于临时表及缓存。 MEMORY 的缺陷就是
对表的大小有限制,太大的表无法缓存在内存中,而且无法保障数据的安全性。

♥️关注,就是我创作的动力

♥️点赞,就是对我最大的认可

♥️这里是小刘,励志用心做好每一篇文章,谢谢大家

本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)

MySQL—存储引擎(下) 的相关文章

  • 使用 Python 2.7 和 MySQLdb 将二进制数据插入 MySQL 中的 blob 列时如何避免编码警告

    我在将二进制数据插入到longblob使用 Python 2 7 中的 MySQLdb 在 MySQL 中的列 但我收到一个编码警告 我不知道如何解决 test py 11 Warning Invalid utf8 character st
  • 如何为 MySQL 和 Postgres 编写不区分大小写的查询?

    我在本地运行 MySQL 数据库进行开发 但部署到使用 Postgres 的 Heroku Heroku 处理几乎所有事情 但我不区分大小写的 Like 语句变得区分大小写 我可以使用 iLike 语句 但我的本地 MySQL 数据库无法处
  • 根据 MySQL 列内容的长度创建索引?

    如何根据值的长度在 MySQL v 5 0 myisam 数据库引擎 中的列上创建索引 它是文本数据类型 最多 7000 个字符 我是否必须添加具有第一列长度的另一列 是的 因为 MySQL 不支持基于函数的索引 例如ADD INDEX m
  • 导入 CSV 以更新表中的行

    大约有 26K 个产品 帖子 每个产品都有如下元值 post id 列是数据库中的产品 ID sku meta key 是每个产品的唯一 ID 我收到了一个新的 CSV 文件 该文件更新了每个产品的 sale price meta key
  • 解码Json数据数组并插入到mysql

    这个问题可能已经在这里问过 但我尝试搜索找不到它 我有如下 Json 数据 CityInfo CityCode 5599 Name DRUSKININKAI CityCode 2003 Name KAUNAS CityCode 2573 N
  • MySQL中是否有类似Oracle中“level”的函数[重复]

    这个问题在这里已经有答案了 我面临一个场景 如果输入是 10 我想要一个数字序列 1 2 3 10 在甲骨文中levelfunction 提供了该功能 我想知道如何在 MySQL 中执行相同的任务 谢谢 您可以在 mysql 中使用此查询
  • 使用 pip3 安装 mysqlclient 时遇到问题

    我正在尝试使用 Django 设置 python 3 6 环境 安装说明说我应该安装 mysqlclient 才能连接到 mySQL 我明白了 dennis django sudo H pip3 install mysqlclient Co
  • WooCommerce:在数据库中查找产品

    我正在使用 WooCommerce 创建一个网站 我想根据用户在主页搜索表单中输入的邮政编码来限制用户可用的产品 为了能够实现这一目标 我必须在 phpMyAdmin 的数据库中指定每个产品的条件 但我似乎找不到它 有谁知道 phpmyAd
  • 为 Mariadb 安装连接器 C

    所以 我想使用 Mariadb 有一个连接器 C https downloads mariadb org connector c https downloads mariadb org connector c 我该如何安装它 坦白说 它的文
  • 是否可以使用“WHERE”子句来选择SQL语句中的所有记录?

    晚上好 我很好奇是否可以在 SQL 语句中创建一个 WHERE 子句来显示所有记录 下面一些解释 随机 SQL 语句 Java JSP示例 正常情况 String SqlStatement SELECT FROM table example
  • 如何使用 PHP 从 MySQL 查询中按升序对值进行排序?

    我使用以下 PHP 脚本从 MySQL 表中获取和更改数据 并将结果打印在 HTML 表中 我希望按升序对数据进行排序 utilization percentage变量 它是由创建的 total client time total avai
  • 在 MySQL 中分割逗号分隔值

    我正在尝试将字符串中以逗号分隔的 值拆分为多列 样本数据 COL1 COL2 COL3 000002 000003 000042 09 31 51 007 004 007 预期输出 Pno Cno Sno 000002 09 007 000
  • ejabberd 16.06 + mysql 5.5.50,消息历史记录不保存

    我使用ejabberd 16 06 mysql 5 5 50 消息历史记录没有保存 我的 ejabberd yml MySQL server odbc type mysql odbc server freldo odbc port 3306
  • php 崩溃后 mysql 表被锁定

    我有一个 MySQL DB 和一个 innoDB 表 我有一个 php 页面 用于连接 锁定表 进行一些更新 然后解锁表 PHP 页面通过 wamp 与 apache 一起提供 php页面将文件上传到数据库 我决定通过上传一个大小大于分配给
  • 物理写入文件已满 - mysql 错误

    我正在使用xampp 每次启动mysql时 我都会在xampp中收到以下错误 Error MySQL shutdown unexpectedly 13 16 14 mysql This may be due to a blocked por
  • 在 MySQL 中将行转置为列

    如何在 MySQL 查询中将行转换为列 您可以将行变成a列与GROUP CONCAT 但您无法以任何自动方式转置整个结果集 您可以编写手动生成每一列的查询 也可以在应用程序中执行此操作 以下是有关编写复杂查询来模拟转置的教程 http ww
  • PHP 的 PDO 可以限制为单个查询吗?

    PHP 的 PDO 允许通过 query 方法或作为准备好的语句同时执行多个查询 以下两个示例均有效 Two SQL queries query SELECT FROM table DROP table Execute via query
  • 数据表 - 服务器端处理 - 数据库列合并

    我目前正在使用 DataTables 1 10 5 服务器端处理功能 http www datatables net examples data sources server side html http www datatables ne
  • 高效插入和更新时检查唯一性

    我的员工表中有 2 列 每列值必须是唯一的 staff code staff name staff id staff code staff name 1 MGT Management 2 IT IT staff 当向表中插入或更新项目时 我
  • 哪个是识别关系或非识别关系中的子表?

    在表之间的识别和非识别关系的上下文中 MySQL 文档大量将表称为父表和子表 如何判断哪个表是父表 哪个表是子表 子表 A K A 弱实体 http en wikipedia org wiki Weak entity 是一个表 其主键属性d

随机推荐

  • Qt易忘样式表总结

    目录 前言 1 Qt设置样式的几种方式 2 几种复合控件的样式设置 QTableWidget QCalendarWidget QTreeWidget QSpinBox QComboBox 前言 在使用Qt框架开发软件时 为了美观和更好的用户
  • 域名购买以及解析域名到服务器IP----史上最详细小白教程没有之一

    昨天 我师父看了我的云服务器配置的博客 给我提了个意见 我觉得非常好 以后我会在截图的时候标清楚步骤的 希望各位博友 以后可以给我多提意见 通过评论的方式也可以 我也将推出更多高质量的文章 目前目标是排名突破前10万 如果想一同学习的 欢迎
  • python后端学习(十)多继承和MRO顺序、再论静态方法和类方法、property属性及应用、魔法属性、with与“上下文管理器”

    多继承和MRO顺序 1 单独调用父类的方法 coding utf 8 print 多继承使用类名 init 发生的状态 class Parent object def init self name print parent的init开始被调
  • leetcode 周赛——2848. 与车相交的点

    题目所属分类 差分数组知识点 原题链接 给你一个下标从 0 开始的二维整数数组 nums 表示汽车停放在数轴上的坐标 对于任意下标 i nums i starti endi 其中 starti 是第 i 辆车的起点 endi 是第 i 辆车
  • 宽字节注入讲解

    我讨厌现在的自己 一边压抑着自己的情绪 一边装作没事的样子 一到深夜就彻底崩溃了 天亮后还要微笑面对生活 网易云热评 一 原理 1 单字节字符集 所有的字符都使用一个字节来表示 比如 ASCII 编码 0 127 2 多字节字符集 在多字节
  • 区块链技术入门——核心概念与原理

    区块链的前世今生 密码朋克 Cypherpunk 是一个邮件组 里面有许多大牛 比特币的底层技术 点对点网络 时间戳 加密技术 工作量证明 可以应用到其他领域 将这些技术提炼出来 就提出了区块链概念 区块链不是单一的技术 而是一系列技术的集
  • ASP.NET Core快速入门(第5章:认证与授权)--学习笔记

    课程链接 http video jessetalk cn course explore 良心课程 大家一起来学习哈 任务31 课时介绍 1 Cookie based认证与授权 2 Cookie based认证实现 3 Jwt认证与授权介绍
  • TCP: SYN ACK FIN RST PSH URG

    三次握手Three way Handshake 一个虚拟连接的建立是通过三次握手来实现的 1 B gt SYN gt A 假如服务器A和客户机B通讯 当A要和B通信时 B首先向A发一个SYN Synchronize 标记的包 告诉A请求建立
  • 金属学复习【3】 --- 二元合金相图和合金的凝固

    一 合金中的相 1 相图中呈现的内容一定是处于热力学平衡态的 即系统自由能最小态 2 纯铁的改变量只有温度和压力 所以我们用温度和压力来制作纯铁的相图 把溶质融到溶剂中 形成的均匀的 单相的物质就是溶体 以特定比例形成的化合物称为化学计量比
  • Linux下执行wget无效问题

    安装好后的CentOS 7想安装个redis学习下 发现不识别wget命令 wget http xxx tar gz 原因是安装CentOS系统的时候安装的最小配置 默认没有安装wget 只需要yum y install wget即可
  • linux桌面动态,ubuntu 中设置动态壁纸

    为了开发android 功能 ubuntu系统也使用了好久时间 作为一个经常使用的系统 不捣鼓捣鼓就太平淡 根据网上的一些介绍 搞了一个动态壁纸出来 用来定时更换壁纸 首先创建一个文件夹 里面三个文件 其余根据自己喜好放入壁纸文件 第一个文
  • C语言黑科技—指针读写

    PS 本人之前对于指针的了解基本为0 更是没有实际使用过指针 后来在开发中学习到了利用指针在固定地址读取或者写入数据的方法 以及利用指针提取数组的方法 这里简单分享一下 手法可能有些粗陋 如果有大佬有其他方法欢迎留言交流 目录 1 利用指针
  • clang

    一 Clang简介 简单来说 Clang是一个编译器 目前用来编译C C Objective C语言 更进一步来说 Clang只是一个编译器前端 其将上述的C类语言编译成一种 汇编语言 中间语言 接着 通过LLVM Low Level Vi
  • Docker打包镜像的两种方式

    前言 Docker镜像是一个特殊的文件系统 既提供了运行时所需的程序 库和资源 还提供了相应的配置参数 只是不包含动态数据 我们可以将任何我们的软件产品打包成镜像 以供服务器能够用Docker直接快速安装并部署运行 System Linux
  • 学会python可以做什么工作,python能做什么项目

    python能做什么工作 现在互联网发展迅速 众多行业巨头 都已经转投到人工智能领域 而人工智能的首选编程语言就是python 所以学好Python能够从事的工作还是很多的 而且前景非常不错 学完python可以应用于以下领域 Web 和
  • 数组实现线程安全的栈

    package quiz 线程安全的栈实现 固定10容量 扩展容量没有用到 public class StackImplUseArray private Object objs new Object 10 栈元素 private int i
  • linux 下工具

    一 文本比较工具 命令行有 colordiff 图形化的有 meld bcompare 二 记事本 tomboy 工具 快捷键 Bold C B Italic C I Strikeout C S Highlight C H Underlin
  • Hibernate学习笔记 单表映射

    建立实体类 配置好SessionFactory之后 我们就可以开始建立一对一的单表映射了 首先需要建立一个实体类 这里Getter Setter toString equals等方法省略了 我们可以方便的使用IDEA或者Eclipse的生成
  • 【分享】ROM厂商刷机工具合集

    1 MTK刷机 SP Flash Tool下载地址 SP Flash Tool v5 1924 Download SmartPhone Flash Tool MTKClient 下载地址 Releases notmyst33d mtkcli
  • MySQL—存储引擎(下)

    作者 小刘在C站 个人主页 小刘主页 每天分享云计算网络运维课堂笔记 努力不一定有回报 但一定会有收获加油 一起努力 共赴美好人生 树高千尺 落叶归根人生不易 人间真情 前言 上一章讲了存储引擎 本章继续 从特点开始 目录 MySQL 1