MySQL学习笔记-存储引擎

存储引擎

一. MySQL体系结构

image-20230328155149347

  • MySQL Server
    • 连接层:连接的处理、认证授权、安全方案、检查是否超过最大连接数等。
    • 服务层:SQL接口、解析器、查询优化器、缓存
    • 引擎层:引擎是数据存储和提取的方式,引擎层有许多引擎可供使用,也可以自定义引擎。索引是在存储引擎层实现的。
    • 存储层:存储数据库的相关数据,包括数据与日志等。

image-20230328155625162

二. 存储引擎简介

什么是存储引擎?

存储引擎是存储数据、建立索引、更新/查询数据等技术的实现方式。

存储引擎是基于表的,而不是基于库的,所以存储引擎也可被称为表类型

  • MySQL 5.5 之后默认存储引擎为InnoDB

image-20230328160011584

1. 在创建表时指定存储引擎

create table {表名}(
	...
)engine = {存储引擎} ...;

2. 查看当前数据库支持的存储引擎

show engines;

image-20230328160517473

三. 存储引擎特点

image-20230328164008325

1. InnoDB

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

1.1 特点

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

1.2 文件

xxx.ibd:xxx代表表名,innoDB引擎的每张表都会对应这样一个表空间文件,存储该表的表结构(frm、sdi)、数据和索引。

  • 参数:innodb_file_per_table:决定是多张表共用一个共享表空间还是每个表都对应一个表空间,目前默认是打开的(每个表都对应一个表空间文件)

1.3 逻辑存储结构

  • TableSpace:表空间
  • Segment:段
  • Extent:区(大小固定:1M)(一个区包含64个页)
  • Page:页(大小固定:16K)
  • Row:行

image-20230328161823252

2. MyISAM

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

2.1 特点

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

2.2 文件

  • .MYD:表中存放的数据
  • .MYI:索引
  • .sdi:存储表结构信息

3. Memory

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

3.1 特点

  • 内存存放(快)
  • hash索引(默认)

3.2 文件

xxx.sdi:存储表结构信息

数据索引在内存中。

四. 存储引擎选择

选择存储引擎时,应该根据应用系统的特点选择合适的存储引擎。

对于复杂的应用系统,还可以根据实际情况选择多种存储引擎进行组合。

image-20230328174749905

原文链接:https://www.cnblogs.com/yellowsea/p/17266163.html

本站文章如无特殊说明,均为本站原创,如若转载,请注明出处:MySQL学习笔记-存储引擎 - Python技术站

(0)
上一篇 2023年4月18日
下一篇 2023年4月18日

相关文章

  • 详解mysql的limit经典用法及优化实例

    详解MySQL的Limit经典用法及优化实例 什么是Limit 在 MySQL 中,LIMIT 子句用于限制 SQL 查询语句的结果集合。使用 LIMIT 子句,我们可以限制返回的行数,也可以通过可选的 OFFSET 参数指定从哪一行开始返回。 基本语法 LIMIT 子句的基本语法如下: SELECT * FROM table_name LIMIT offs…

    MySQL 2023年5月19日
    00
  • MySQL优化服务器,提高MySQL的运行速度!

    MySQL是一款开放源代码的关系型数据库管理系统。在使用MySQL时,为了提高系统的性能和稳定性,通常需要对服务器进行优化。本文将详细介绍如何优化MySQL服务器,以提高其运行速度。 升级硬件 首先,升级硬件是提高服务器性能的首要条件。硬件升级主要包括CPU、内存和硬盘。在升级硬件时,应该根据服务器的实际情况选择合适的硬件配置。 优化MySQL配置文件 My…

    MySQL 2023年3月10日
    00
  • 关于MySQL实现指定编码遇到的坑

    针对MySQL实现指定编码遇到的坑,我们可以采取以下的攻略: 第一步:确认数据库字符集和排序规则 在MySQL中,字符集和排序规则是非常重要的,因为它们直接影响到数据的存储和查询。因此,在执行任何操作之前,我们需要先确认数据库当前的字符集和排序规则是否符合要求。 我们可以通过如下命令来查看数据库的字符集和排序规则: SHOW VARIABLES LIKE ‘…

    MySQL 2023年5月18日
    00
  • 最新版MySQL 8.0.22下载安装超详细教程(Windows 64位)

    以下是针对“最新版MySQL 8.0.22下载安装超详细教程(Windows 64位)”的完整攻略: 下载MySQL 8.0.22 访问MySQL官网,从中选择最新的适合你系统(这里选择的是Windows (x86, 64-bit), ZIP Archive)的MySQL 8.0.22版本,点击下载. 安装MySQL 8.0.22 安装MySQL 8.0.2…

    MySQL 2023年5月18日
    00
  • mysql性能优化脚本mysqltuner.pl使用介绍

    MySQL是一种流行的关系型数据库,但是在实际应用中,我们可能会遇到性能瓶颈,需要对MySQL进行性能优化。而mysqltuner.pl这个脚本,则是一个非常常用的MySQL性能优化小工具。本篇攻略将详细介绍mysqltuner.pl的使用步骤,以及如何根据mysqltuner.pl的结果进行性能优化。 1. 安装mysqltuner.pl脚本 首先,需要在…

    MySQL 2023年5月19日
    00
  • MySQL中or、in、union与索引优化详析

    下面是关于MySQL中or、in、union与索引优化的详细攻略: 1. 索引的基本知识 在进入or、in、union的优化之前,我们先来了解一下索引的基本知识。在MySQL中,可以使用主键、唯一索引、普通索引等多种索引,来提升查询性能。索引的作用是对数据库表中的一列或多列进行排序的一种结构,类似于书籍的目录,可以提高数据的检索速度。 在使用索引时,需要注意…

    MySQL 2023年5月19日
    00
  • 第06章 索引的数据结构

    1. 为什么使用索引 索引是存储引擎用于快速找到数据记录的一种数据结构,就好比一本教科书的目录部分,通过目录中找到对应文章的页码,便可快速定位到需要的文章。MySQL中也是一样的道理,进行数据查找时,首先查看查询条件是否命中某条索引,符合则通过索引查找相关数据,如果不符合则需要全表扫描,即需要一条一条地查找记录,直到找到与条件符合的记录。 如上图所示,数据库…

    MySQL 2023年4月17日
    00
  • zabbix添加mysql自定义监控项

    $ vi /etc/zabbix/zabbix_agentd.d/userparameter_mysql.conf #UserParameter=mysql.status[*],echo “show global status where Variable_name=’$1′;” | HOME=/etc/zabbix mysql -N | awk ‘{pri…

    MySQL 2023年4月13日
    00
合作推广
合作推广
分享本页
返回顶部