mysql defaultstorageengine_MySQL存储引擎MyISAM与InnoDB

原标题:MySQL存储引擎MyISAM与InnoDB

存储引擎的实质就是如何实现存储数据,为存储数据建立索引以及查询、更改、删除数据等技术实现的方法。

MySQL支持插件式的表存储引擎,这种独有的插件式体系架构,让存储引擎有了依赖应用的多样性。其中较为知名的存储引擎为MyISAM与InnoDB.

MySQL系统中,存储引擎处于文件系统之上,在数据保存到数据文件之前会先传输到存储引擎,然后按照各个存储引擎的存储格式进行数据存储。使用这种存储引擎的主要优点在于,仅仅需要提供特殊应用的特性即可;数据库中的系统开销较小,更具有有效和高效的数据库性能。

MyISAM存储引擎特点

1、不支持事务处理,需要事务支持的系统不能使用MyISAM作为存储引擎

2、表级锁定形式,数据在更新时会锁定整个表。

3、数据库在读写的过程中相互阻塞: 在数据写入的过程中阻塞用户对数据的读取; 在数据读取的过程中阻塞用户写入数据;

4、可以通过key_buffer_size来设置缓存索引,提高访问的性能,减少磁盘IO的压力。

5、采用MyISAM存储引擎不支持外键约束,只支持全文索引。

6、采用MyISAM存储引擎进行数据单独写入或者读取,速度较快且占用资源相对要少。

7、MyISAM存储的文件类型: .frm 文件存储表定义; 数据文件扩展名为.MYD(MYDATA); 索引文件扩展名为.MYI(MYIndex);

InnoDB存储引擎特点

1、支持事务处理,支持四个事务隔离级别。

2、行级锁定,但是全表扫描时会锁定整个表。

3、读写阻塞与事务隔离级别相关。

4、具有非常高效的缓存特性,能缓存索引,也能缓存数据。

5、表与主键以簇的方式存储。

6、支持分区、表空间,类似oracle数据库。

7、支持外键约束,MySQL5.5以前不支持全文索引,后面的版本支持。

8、适合对硬件资源要求较高的场合。

存储引擎的更改与选择方式

查看数据库使用的存储引擎方法:

show table status from school where name='info';

或者:

show create table info;

配置存储引擎的几种方式:

1、使用alter table命令修改: (修改现有表的存储引擎)

alter table info engine=MyISAM/InnoDB; //进入数据库操作

2、修改默认存储引擎: (针对后面新创建的表格起作用)

#vim /etc/my.cnf

default-storage-engine=MyISAM/InnoDB //在[mysql]服务栏下设置默认存储引擎

3、在创建表时指定使用的存储引擎种类: //在mysql模式下

create table test(name varchar(10)) engine=InnoDB;

show create table test;

4、mysql_convert_table_format命令可以批量转换存储引擎 注:此种工具使用只能存在于MySQL5.5版本以前。

yum install perl-DBI perl-DBD-MySQL -y //安装操作运行库

默认情况下只能将已存在的InnoDB的存储引擎更改为MyISAM形式,若需要反过来更改需要更改命令执行脚本:

vim /usr/local/mysql/bin/mysql_convert_table_format

(第四种同时更改多表的存储引擎为在MySQL5.5版本为例)

$opt_help=$opt_version=$opt_verbose=$opt_force=0;

$opt_user=$opt_database=$opt_password=undef;

$opt_host="localhost";

$opt_socket="";

$opt_engine="MYISAM";

$opt_port=0;

$exit_status=0;

GetOptions(

"e|engine|type=s" => $opt_type, //32行,type更改为engine即可

"f|force" => $opt_force,

"help|?" => $opt_help,

"h|host=s" => $opt_host,

"p|password=s" => $opt_password,

"u|user=s" => $opt_user,

"v|verbose" => $opt_verbose,

"V|version" => $opt_version,

"S|socket=s" => $opt_socket,

"P|port=i" => $opt_port

然后用:(Linux模式下利用该命令)

mysql_convert_table_format --host=localhost --user=root --password=abc123 --socket=/tmp/mysql.socket --engine=InnoDB school test01 test02

--host=localhost //表示本地数据库

--user=root //表示登录用户

--password=abc123 //表示登录密码

--socket=/tmp/mysql.socket //指定socket目录

--engine-InnoDB //需要更改后的存储引擎

school //指定需要更改的库

test01 test02 //需要同时更改的表

可以同时更改test01 test02多个表的存储引擎。返回搜狐,查看更多

责任编辑:

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值