阿里云-云小站(无限量代金券发放中)
【腾讯云】云服务器、云数据库、COS、CDN、短信等热卖云产品特惠抢购

MySQL存储引擎MyISAM与InnoDB

217次阅读
没有评论

共计 2267 个字符,预计需要花费 6 分钟才能阅读完成。

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

  • 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 多个表的存储引擎。

正文完
星哥玩云-微信公众号
post-qrcode
 0
星锅
版权声明:本站原创文章,由 星锅 于2022-01-22发表,共计2267字。
转载说明:除特殊说明外本站文章皆由CC-4.0协议发布,转载请注明出处。
【腾讯云】推广者专属福利,新客户无门槛领取总价值高达2860元代金券,每种代金券限量500张,先到先得。
阿里云-最新活动爆款每日限量供应
评论(没有评论)
验证码
【腾讯云】云服务器、云数据库、COS、CDN、短信等云产品特惠热卖中