翼度科技»论坛 编程开发 mysql 查看内容

MySQL学习笔记-存储引擎

5

主题

5

帖子

15

积分

新手上路

Rank: 1

积分
15
存储引擎

一. MySQL体系结构



  • MySQL Server

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


二. 存储引擎简介

什么是存储引擎?
存储引擎是存储数据、建立索引、更新/查询数据等技术的实现方式。
存储引擎是基于表的,而不是基于库的,所以存储引擎也可被称为表类型


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

1. 在创建表时指定存储引擎
  1. create table {表名}(
  2.         ...
  3. )engine = {存储引擎} ...;
复制代码
2. 查看当前数据库支持的存储引擎
  1. show engines;
复制代码

三. 存储引擎特点


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:行

2. MyISAM

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


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


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

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


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

xxx.sdi:存储表结构信息
数据索引在内存中。
四. 存储引擎选择

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


来源:https://www.cnblogs.com/yellowsea/p/17266163.html
免责声明:由于采集信息均来自互联网,如果侵犯了您的权益,请联系我们【E-Mail:cb@itdo.tech】 我们会及时删除侵权内容,谢谢合作!

本帖子中包含更多资源

您需要 登录 才可以下载或查看,没有账号?立即注册

x

举报 回复 使用道具