2:引擎
指定引擎
create table account1( id int not null auto_increment, name varchar(20) default null, -- 六位数里有两位小数 money double(6,2) default 0, primary key (id) ) engine= InnoDB;
create table my_myisam( id int, name varchar(10) ) engine = MyISAM; create table my_memory( id int, name varchar(10) ) engine = Memory;
查看当前数据库支撑的引擎
show engines ;
3:InnoDB
概念:InnoDB是一种兼顾高可靠性和高性能的通用存储引擎,
在 MySQL 5.5 之后,InnoDB是默认的 MySQL 存储引擎。
特点:
DML操作遵循ACID模型,支持事务;
行级锁,提高并发访问性能;
支持外键FOREIGN KEY约束,保证数据的完整性和正确性;
文件:在写mysql语句的文件里有(.ibd文件),xxx.ibd:xxx代表的是表名。innoDB引擎的每张表都会对应这样一个表空间文件。
ibd文件有三部分内容:表结构(frm-早期的 、sdi-新版的)、数据和索引。
逻辑存储结构:
表空间:InnoDB存储引擎逻辑结构的最高层,
ibd文件其实就是表空间文件,在表空间中可以 包含多个Segment段。
段:表空间是由各个段组成的, 常见的段有数据段、索引段、回滚段等。
InnoDB中对于段的管理,引擎自身完成,不需要人为操作,一个段中包含多个区。
区:区是表空间的单元结构,每个区的大小为1M。
默认情况下, InnoDB存储引擎页大小为 16K, 即一个区中一共有64个连续的页。
页:页是组成区的最小单元,页也是InnoDB 存储引擎磁盘管理的最小单元,
每个页的大小默 认为 16KB。
为了保证页的连续性,InnoDB 存储引擎每次从磁盘申请 4-5 个区。
行:InnoDB 存储引擎是面向行的,也就是说数据是按行进行存放的,
每一行中除了定义表时 所指定的字段以外,包含两个隐藏字段(后面会详细介绍)。
4:Myisam
概念:MyISAM是MySQL早期的默认存储引擎。
特点:
不支持事物(ACID)
不支持行级锁,支持表锁
不支持外键
文件:
xxx.sdi:存储表结构信息
xxx.MYD: 存储数据
xxx.MYI: 存储索引
5:Memory
概念:Memory引擎的表数据时存储在内存中的,由于受到硬件问题、或断电问题的影响,
只能将这些表作为 临时表或缓存使用。
特点:
内存储存
支持hash索引,查询效率高,增删效率低。
文件:xxx.sdi:存储表结构信息
6:索引
概念:索引(index)是帮助MySQL高效获取数据的数据结构(有序)。
全表扫描:从第一天数据查询到最后一条数据。
优点:
提高数据检索的效率,降低数据库 的IO成本。
通过索引列对数据进行排序,降低 数据排序的成本,降低CPU的消 耗。
缺点:
索引列也是要占用空间的。
索引大大提高了查询效率,同时却也降低更新表的速度,
如对表进行INSERT、UPDATE、DELETE时,效率降低。
7:B+树
为啥不用二叉树作为索引?
1:顺序插入时,会形成一条链表,查询效率低
2:层级较深,某些情况下相当于全表扫描
为啥不使用红黑树作为索引?
因为一个节点最多只能有两个子节点。数据量大时,层级较深。