linux怎么查看本机内存大小
245
2022-10-15
MySQL存储引擎MyISAM和InnoDB
MySQL存储引擎MyISAM和InnoDB
存储引擎
在MySQL中的数据拥有各种不同的技术存储文件或内存中。这些技术中的每一种技术都使用不同的存储机制、索引技巧、锁定水平并且最终提供广泛的不用的功能和能力。通过选择不同的技术,能够获得额外的速度或者功能,从而改善应用的整体功能。这些不同的技术以及配套的相关功能在MySQL中被称之为存储引擎。
MyISAM存储引擎
MyISAM存储引擎是MySQL关系数据库系统5.5版本之前默认的存储引擎。
特点
1、不支持事务
2、表级锁定形式,数据在更新时锁定整个表
3、数据库在读写过程中相互堵塞:
1)、在数据写入的过程中阻塞用户读数据的读取 2)、在数据读取的过程中阻塞用户写入数据
4、可以通过key_buffer_size来设置缓存索引,提高访问的性能,减少磁盘IO的压力
5、采用MyISAM存储引擎进行行数据单独写入或读取,速度较块且占用资源相对较少
6、MyISAM存储引擎不支持外键约束,只支持全文索引
7、每个MyISAM在磁盘上存储成三个文件,每一个的名字均以表的名字开始,扩展名指出文件类型:
1)、.frm 文件存储表定义。 2)、数据文件的扩展名为:.MYD(MYData)。 3)、索引文件的扩展名为:.MYI(MYIndex)。
InnoDB存储引擎
特点
1、支持事物
2、行级锁定,但是全盘扫描仍然会是表级锁定。
3、读写阻塞与事务隔离级别相关
4、具有非常高效的缓存特性,能缓存索引,也能缓存数据
5、表与主键以簇的方式存储
6、支持分区、表空间,类似Oracle数据库
7、支持外键约束,
8、适合对硬件资源要求比较高的场合
配置合适的存储引擎
1、查看MySQL默认使用的存储引擎
mysql -u root -p #进入MySQL show engines; #查看默认存储引擎
2、查看表存储引擎类型
使用 show table status 命令查看:
mysql -u root -p show table status from test where name='test'; #查看test数据库中的test表的存储引擎类型
使用show create 查看表存储引擎类型:
mysql -u root -p use test; #使用test数据库 show create table test; #查看test表的存储引擎类型
3、修改存储引擎
使用 alter table命令修改(只能修改已存在的表):
mysql -u root -p use test; alter table test engine=MyISAM; #修改test表的存储引擎类型 show create table test;
修改MySQL的配置文件my.cnf,可以指定defaut-storage-engine选项设置默认的存储引擎(只试用于新创建的表,已存在表的存储引擎类型不变):
vim /etc/my.cnf #编辑配置文件
#省略内容 [mysqld] default-storage-engines=MyISAM #省略内容
systemctl restart mysqld.service #重启MySQL服务
使用create table创建表时用engine指定存储引擎(现在数据库的默认存储引擎为MyISAM);
mqsql -u root -p use test; create table test01(id int) engine=InnoDB; #创建存储引擎为InnoDB的表 show create table test01;
使用mysql_convert_table_format命令可以批量转换存储引擎(只使用于MySQL5.5版本);
yum install prel-DBI -y yum install prel-BDB-MySQL -y #安装perl对MySQL的模块操作 mysql_convert_table_format --user=root --password=密码 --socket=/temp/mysql.sock --engine=MyISAM test test 但当使用此命令将存储引擎类型更改为InnoDB时,会出现报错,所以需要修改其命令的脚本文件 vim /use/local/mysql/bin/mysql_convert_table_format
#省略内容 "e|engine|type=s" =>\$opt_engine, #将32行中的\$opt_type更改为\$opt_engine #省略内容
重新使用命令即可 mysql_convert_table_format --user=root --password=密码 --socket=/temp/mysql.sock --engine=InnoDB test test
版权声明:本文内容由网络用户投稿,版权归原作者所有,本站不拥有其著作权,亦不承担相应法律责任。如果您发现本站中有涉嫌抄袭或描述失实的内容,请联系我们jiasou666@gmail.com 处理,核实后本网站将在24小时内删除侵权内容。
发表评论
暂时没有评论,来抢沙发吧~