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

原文地址:http://blog.51cto.com/13659253/2136258

时间: 2024-08-06 20:04:46

MySQL存储引擎MyISAM与InnoDB的相关文章

MySQL存储引擎 - Myisam和Innodb

Mysql有两种存储引擎:InnoDB与Myisam,下表是两种引擎的简单对比   MyISAM InnoDB 构成上的区别: 每个MyISAM在磁盘上存储成三个文件.第一个 文件的名字以表的名字开始,扩展名指出文件类型..frm文件存储表定义.数据文件的扩 展名为.MYD (MYData).索引文件的扩 展名是.MYI (MYIndex). 基于磁盘的资源是InnoDB表空间数据文件和它的日志文件,InnoDB 表的 大小只受限于操作系统文件的大小,一般为 2GB 事务处理上方面: MyISA

MySQL存储引擎MyISAM和InnoDB

MySQL存储引擎MyISAM和InnoDB 存储引擎 在MySQL中的数据拥有各种不同的技术存储文件或内存中.这些技术中的每一种技术都使用不同的存储机制.索引技巧.锁定水平并且最终提供广泛的不用的功能和能力.通过选择不同的技术,能够获得额外的速度或者功能,从而改善应用的整体功能.这些不同的技术以及配套的相关功能在MySQL中被称之为存储引擎. MyISAM存储引擎 MyISAM存储引擎是MySQL关系数据库系统5.5版本之前默认的存储引擎. 特点 1.不支持事务 2.表级锁定形式,数据在更新时

解析MySQL的体系架构及学习Mysql存储引擎MyISAM和InnoDB

mysql体系结构: 由:连接池组件.管理服务和工具组件.sql接口组件.查询分析器组件.优化器组件. 缓冲组件.插件式存储引擎.物理文件组成.mysql是独有的插件式体系结构,各个存储引擎有自己的特点. mysql各个存储引擎概述: (1) innodb存储引擎:[/color][/b] 面向oltp(online transaction processing).行锁.支持外键.非锁定读.默认采用repeaable级别(可重复读)通过next-keylocking策略避免幻读.插入缓冲.二次写

MySQL存储引擎MyISAM与InnoDB的优劣

使用MySQL当然会接触到MySQL的存储引擎,在新建数据库和新建数据表的时候都会看到. MySQL默认的存储引擎是MyISAM,其他常用的就是InnoDB了. 至于到底用哪种存储引擎比较好?这个问题是没有定论的,需要根据你的需求和环境来衡量.所以对这两种引擎的概念.原理.异同和各自的优劣点有了详细的了解之后,再根据自己的情况选择起来就容易多了. MyISAM InnoDB 存储结构 每张表被存放在三个文件: frm-表格定义 MYD(MYData)-数据文件 MYI(MYIndex)-索引文件

Mysql存储引擎MyIsAM和InnoDB区别

Mysql 数据库中,最常用的两种引擎是innordb 和myisam.InnoDB 是Mysql 的默认存储引擎. 两者的区别: 1.事务处理上方面MyISAM:强调的是性能,查询的速度比InnoDB 类型更快,但是不提供事务支持.InnoDB:提供事务支持. 2.外键MyISAM:不支持外键, InnoDB:支持外键. 3.锁MyISAM:只支持表级锁, InnoDB:支持行级锁和表级锁,默认是行级锁,行锁大幅度提高了多用户并发操作的性能.innodb 比较适合于插入和更新操作比较多的情况,

MySQL存储引擎MyISAM与InnoDB区别

1.MySql默认存储引擎的变迁 在MySql5.1之前的版本中,默认的搜索引擎是MyISAM,从MySQL5.5之后的版本中,默认的搜索引擎变更为InnoDB. 2.存储结构 MyISAM:每个MyISAM在磁盘上存储成三个文件.第一个文件的名字以表的名字开始,扩展名指出文件类型. .frm文件存储表定义: 数据文件的扩展名为.MYD(MYData): 索引文件的扩展名是.MYI(MYIndex): InnoDB:所有的表都保存在同一个数据文件中(也可能是多个文件,或者是独立的表空间文件),I

MySQL存储引擎MyISAM与InnoDB的区别

一.InnoDB支持事务,MyISAM不支持,这一点是非常之重要.事务是一种高级的处理方式,如在一些列增删改中只要哪个出错还可以回滚还原,而MyISAM就不可以了. 二.MyISAM适合查询以及插入为主的应用,InnoDB适合频繁修改以及设计到安全性就高的应用 三.InnoDB支持外键,MyISAM不支持 四.MyISAM是默认引擎,InnoDB需要指定 五.InnoDB不支持FULLTEXT类型的索引 六.InnoDB中不保存表的行数,如select count(*) from table时,

mysql 存储引擎 myisam innodb 区别

虽然MySQL里的存储引擎不只是MyISAM与InnoDB这两个,但常用的就是它俩了.可能有站长并未注意过MySQL的存储引擎,其实存储引擎也是数据库设计里的一大重要点,那么博客系统应该使用哪种存储引擎呢?下面我们分别来看两种存储引擎的区别. MySQL存储引擎MyISAM与InnoDB的区别 一.InnoDB支持事务,MyISAM不支持,这一点是非常之重要.事务是一种高级的处理方式,如在一些列增删改中只要哪个出错还可以回滚还原,而MyISAM就不可以了. 二.MyISAM适合查询以及插入为主的

MySQL 储存引擎 MyISAM 和 InnoDB 配置

MySQL 存储引擎 MyISAM 和 InnoDB 配置 MyISAM 和 InnoDB 最大特点: MyISAM : ① 不支持事务 . ② 表级锁定形式 ,数据在更新时锁定整个表 . ③ 不支持外键约束 ,只支持全文索引 . ④ 数据库在读取过程中相互阻塞 . ⑤ 数据单独写入或读取 , 速度较快且占用资源相对要少 . InnoDB: ① 支持事务 . ② 行级锁定 ,但是全表扫描仍然会是表级锁定 . ③ 支持分区.表空间 ,类似Oracle 数据库 . ④ 读写阻塞与事务隔离级别相关 .