mysql存储引擎

1 概述

  1. MYSQL5.0支持的存储引擎包括MYISAM,InnoDB,BDB,MEMORY,MERGE,EXAMPLE,NDB Cluster,ARCHIVE,CSV,BLACKHOLE,FEDERATED等,其中InnoDB和BDB提供事务安全表,其他存储引擎都是非事务安全表.MySQL5.5之前默认引擎为MyISAM,之后默认的为InnoDB

  2. 查询默认存储引擎:
    show variables like ‘%storage_engine%’;

  3. 查询数据库支持的存储引擎
    show engines

  4. 设置表的存储引擎
    create table ai(
    i bigint(20) not null auto_increment,
    primary key(i),
    )engine=InnoDB default charset = gbk;

2 各种引擎的存储特性

在这里插入图片描述

    2.1 MyISAM

1)MyISAM是MySQL默认的存储引擎.MyISAM不支持事务,也不支持外键.优势是访问速度快,对事物完整性没有要求或者以select,insert为主的应用基本上都可以使用这个引擎来创建表.

2)每个MyISAM在磁盘上存储成3个文件,其文件名和表名相同,但扩展名分别是:…frm(存储表定义),.MYD(MYData.存储数据),.MYI(MYIndex,存储索引)

3)数据文件和索引问津可以放置在不同的目录,平均分布IO,获得更快的速度.建表的时候可以通过DATA DIRECTORY和INDEX DIRECTORY指定索引文件和数据文件的路径

4)MyISAM类型的表可能损坏,可以用check table语句来检查MyISAM表的健康状态,用REPAIR来修复一个损坏的MyISAM表

5)MyISAM的表还支持3中不同的存储格式,分别是静态表,动态表,压缩表
    静态表是默认的存储格式.静态表中的字段都是非变长字段,每个记录都是固定长度的,优点是存储非常迅速,容易缓存,出现故障统一恢复;缺点是占用的空间通常比动态表多.静态表的数据在存储时会按照列的宽度定义补足空格,但是在查询的时候会将这些空格去掉,如果要存储的数据尾部有空格,那么在查询的时候也会被去掉.但是头部的空格不会
    动态表中包含变长字段,记录不是固定长度的,优点是存储空间相对较少,但是频繁的更新删除记录,会产生碎片,需要定期的执行OPTMIZF TABLE语句或myisamchk-r命令来改善性能,但是出现故障时恢复相对困难.

    2.2 InnoDB

InnoDB支持事务,但是对比MyISAM的存储引擎,InnoDB写的处理效率差一些,并且会占用更多的磁盘空间以保留数据和索引
1)自动增长列
InnoDB表的自动增长列可以手工插入,但是插入的值如果是空或者0,则实际插入的将是自动增长后的值.可以通过Alter table *** auto_increment=n语句强制设置自动增长列的初始值,默认从1开始.但是该强制的默认值是保留在内存中的,如果该值在使用之前数据库重新启动,那么这个强制的默认值就会丢失,需要重设置.
可以使用last_insert_id()查询当前线程最后插入记录使用的值,如果一次插入了多条记录,则返回第一条记录使用的自动增长值
对于InnoDB表,自动增长列必须是宋莹,如果是组合索引,也必须是组合索引的第一列.但是对于MyISAM表,自动增长列可以是组合索引的其他列

  1. 外键约束
    MySQL支持外键的只有InnoDB,在创建外键的时候,要求附表必须有对应的索引,字表在创建外键的时候也会自动创建对应的索引
    在创建索引是,可以指定删除,更新父表时,对字表进行的相应操作,包括RESTRICT,CASCADE,SET NULL和NO ACTION.其中RESTRICT和NO ACTION相同,是指限制在子表有关联记录的时候父表不能更新;CASCADE表示父表在更行或者删除时,更新或者删除字表记录,SET NULL则表示父表在更新或者删除的时候,字表对应的字段被SET NULL

3)存储方式
InnoDB存储表和索引有以下两种方式:
一:使用共享表空间存储,表结构保存在.frm文件中,数据和索引保存在innodb_data_home_dir和innodb_data_file_path定义的表空间中,可以是多个文件
二:使用多表空间存储,表结构依然保存在.frm文件中,但是表的数据和索引单独保存在.ibd中.如果是个分区表,则每个分区对应单独的.ibd文件,文件名是"表名+分区名",可以在建分区的时候指定每个分区的数据文件的位置,以此来将表的IO均匀分布在多个磁盘上

    要使用多表空间的存储方式,需要设置参数innodb_file_per_table,并且重新启动服务才可以生效,对已有的表依然使用共享空间存储,新建的表才会按照多表空间的方式创建,反过来也一样.

    多表空间的数据文件大小没有限制,不需要设置初始大小,也不需要设置文件的最大限制,扩展大小等参数

    可以通过alter table tbl_name discard tablespace和alter table tbl_name import tablespace将备份恢复到数据库中,但是只能恢复到表原来所在的数据库中,如果要恢复到目标数据库,则需要通过mysqldump和mysqlimport来实现

    2.3 MEMORY

1)MEMORY存储引擎使用存在于内存中的内容来创建表.每个MEMORY表只实际对应一个磁盘文件,格式是.frm.MEMORY类型的表访问很快,因为数据是放在内存中的,并且默认使用hash索引,但是一旦服务关闭,表中的数据就会丢失

2)在启动MySql服务的时候使用–init-file选项,把INSERT INTO …SELECT 或LOAD DATA INFILE这样的语句放在文件中,就可以在服务启动时加载数据到表

3)服务器需要足够的内存来维持同一时间使用的memory表,当不在需要memory表的内容时,要释放被memory使用的内存,可以使用delete from或truncate table 或者删除整个表drop table

4)memory表受max_heap_table_size系统变量的约束,默认值为16M,可以根据需要调整,定义MEMORY表时,也可以通过MAX_ROWS指定表的最大行数

MEMORY表主要用于存储那些内容变化不频繁的表,或者作为统计操作的中间表

    2.4 MERGE

MERGE存储是一组MyISM表的组合,这些MyISM表必须结构完全相同,MERGE表本身并没有数据,对MERGE表的查询更新删除操作,实际上是对内部的MyISAM表进行的,使用FIRST或LAST值使得插入操作相应的作用在第一个或者最后一个表上,不定义这个子句或者定义为NO,表示不能对这个MERGE表执行插入操作
建表示例如下:
在这里插入图片描述
可以向payment_2006和payment_2007分别插入数据,也可以向payment_all表插入数据,但是payment_all定义的是INSERT_METHOD是last,所以最终数据会被插入到payment_2007

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值