MySQL学习(11):存储引擎

1.mysql服务端体系结构

mysql服务端可分为4层:连接层、服务层、引擎层、存储层

*连接层是用来与客户端交互的,包括身份验证、密码修改、远程登录等都由连接层管理

*mysql5.5版本后默认的存储引擎是InnoDB

*不同的存储引擎对应的索引结构不一样

2.什么是存储引擎

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

*存储引擎是基于表的,而不是基于库的.

*存储引擎也可被称为表类型

3.查看与指定存储引擎

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

show engines;

输入指令后,可得到如下结果:

*在InnoDB之前,mysql的默认存储引擎是MyISAM

*MEMORY使用内存来存储,通常用来存储临时表

3.2指定存储引擎

create table 表名(
 字段1 类型1,
 ...
 字段n 类型n
)engine=存储引擎名;

同一个库的不同表可以指定不同的存储引擎

4.InnoDB、MyISAM、MEMORY

4.1InnoDB

4.1.1InnoDB特性

*支持事务的4个特性:原子性、一致性、隔离性、持久性

*行级锁,提高并发访问性能

*支持外键 FOREIGN KEY约束,保证数据的完整性和正确性

4.1.2InnoDB文件

*InnoDB引擎的每张表都会对应一个表空间文件:xxx.ibd,xxx代表的是表名。

*表空间文件存储该表的表结构(frm、sdi)、数据和索引。

*InnoDB引擎有个默认开启的参数:innodb_file _per_table,它代表每张表会各有各的表空间文件。

表空间文件在磁盘中的位置,可按下图示例查找:

4.1.3InnoDB逻辑结构

InnoDB在逻辑上可以分为5层,由高到低为:

TableSpece:表空间

Segment:段

Extent:区

Page:页

Row:行

*page页是磁盘存储的最小单位

*page大小固定为16K,Extent区的大小固定为1M,所以一个区能存储64个页

4.2MyISAM

特性:

*不支持事务、外键

*支持表锁,不支持行锁

*访问速度快

文件:

MyISAM会把表分成3种文件存储

xxx.sdi:存储表结构信息

xxx.MYD:存储表内数据

xxx.MYI:存储索引

4.3MEMORY

特性:

*内存存放

*hash索引(默认)

文件:

因为数据都存在内存中,所以只有一种文件

xxx.sdi:存储表结构信息

4.4三者对比

三者的应用场景:

InnoDB:对事务的完整性有比较高的要求,在并发条件下要求数据的一致数据操作除了插入和查询之外,还包含很多的更新、删除操作。

MyISAM:以读操作和插入操作为主,只有很少的更新和删除操作,并且对事务的完整性、并发性要求不是很高。

MEMORY:用于临时表及缓存。对表的大小有限制,太大的表无法缓存在内存中,而且无法保障数据的安全性。

*大部分的mysql表操作都是使用的InnoDB

*MyISAM可被非SQL数据库MongoDB替代

*MEMORY可被非SQL数据库redis替代

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值