加入收藏 | 设为首页 | 会员中心 | 我要投稿 常州站长网 (https://www.0519zz.com/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 站长学院 > MySql教程 > 正文

mysql数据库中MyISAM与InnoDB差异及性能详谈

发布时间:2022-06-15 14:23:29 所属栏目:MySql教程 来源:互联网
导读:在mysql数据库中我们最常用的数据存储引擎包括有MyISAM与InnoDB,下面我们来分析关于MyISAM与InnoDB性能与区别用法吧. MyIASM是IASM表的新版本,有如下扩展: 每张MyISAM 表被存放在三个文件,frm 文件存放表格定义,数据文件是MYD (MYData) , 索引文件是MYI (M
  在mysql数据库中我们最常用的数据存储引擎包括有MyISAM与InnoDB,下面我们来分析关于MyISAM与InnoDB性能与区别用法吧.
 
 
  MyIASM是IASM表的新版本,有如下扩展:
 
  每张MyISAM 表被存放在三个文件,frm 文件存放表格定义,数据文件是MYD (MYData) , 索引文件是MYI (MYIndex) 引伸。
 
  因为MyISAM相对简单所以在效率上要优于InnoDB..小型应用使用MyISAM是不错的选择.
 
  MyISAM表是保存成文件的形式,在跨平台的数据转移中使用MyISAM存储会省去不少的麻烦.
 
  以下是一些细节和具体实现的差别:
 
  1.InnoDB不支持FULLTEXT类型的索引。
 
  2.InnoDB 中不保存表的具体行数,也就是说,执行select count(*) from table时,InnoDB要扫描一遍整个表来计算有多少行,但是MyISAM只要简单的读出保存好的行数即可。注意的是,当count(*)语句包含 where条件时,两种表的操作是一样的。
 
  3.对于AUTO_INCREMENT类型的字段,InnoDB中必须包含只有该字段的索引,但是在MyISAM表中,可以和其他字段一起建立联合索引。
 
  4.DELETE FROM table时,InnoDB不会重新建立表,而是一行一行的删除。
 
  5.LOAD TABLE FROM MASTER操作对InnoDB是不起作用的,解决方法是首先把InnoDB表改成MyISAM表,导入数据后再改成InnoDB表,但是对于使用的额外的InnoDB特性(例如外键)的表不适用。
 
  另外,InnoDB表的行锁也不是绝对的,如果在执行一个SQL语句时MySQL不能确定要扫描的范围,InnoDB表同样会锁全表,例如update table set num=1 where name like “%aaa%”.
 
 
  具体可以看看下表:MyISAM InnoDB
 
  构成上区别,每个MyISAM在磁盘上存储成三个文件,文件名为表名,扩展名为文件类型.
 
  .frm 文件存储表定义;
 
  .MYD(MYData) 数据文件的扩展名;
 
  .MYI(MYIndex) 索引文件的扩展名,基于磁盘的资源是InnoDB表空间数据文件和它的日志文件,InnoDB 表的大小只受限于操作系统文件的大小,一般为 2GB.
 
  事务处理方面 MyISAM类型的表强调的是性能,其执行速度比InnoDB类型更快,但是不提供事务支持。
 
  InnoDB提供事务支持事务,外部键等高级数据库功能.
 
  锁 表级锁 行级锁
 
  InnoDB表的行锁也不是绝对的,如果在执行一个SQL语句时MySQL不能确定要扫描的范围,InnoDB表同样会锁全表,例如update table set num=1 where name like “%aaa%”
 
  select、insert、update、delete操作 如果执行大量的 SELECT,MyISAM 是更好的选择。
 
  1.如果你的数据执行大量的INSERT或UPDATE,出于性能方面的考虑,应该使用InnoDB表。
 
  2.DELETE FROM table时,InnoDB不会重新建立表,而是一行一行的删除。
 
  3.LOAD TABLE FROM MASTER操作对InnoDB是不起作用的,解决方法是首先把InnoDB表改成MyISAM表,导入数据后再改成InnoDB表,但是对于使用的额外的InnoDB特性(例如外键)的表不适用。
 
  对于AUTO_INCREMENT类型的字段 必须包含只有该字段的索引 可以和其他字段一起建立联合索引
 
  InnoDB不支持FULLTEXT类型的索引。
 
  MyISAM类型的二进制数据文件可以在不同操作系统中迁移
 
  以下是一些细节和具体实现的差别:
 
  InnoDB不支持FULLTEXT类型的索引。
 
  InnoDB 中不保存表的具体行数,也就是说,执行select count(*) from table时,InnoDB要扫描一遍整个表来计算有多少行,但是MyISAM只要简单的读出保存好的行数即可。注意的是,当count(*)语句包含 where条件时,两种表的操作是一样的。
 
  对于AUTO_INCREMENT类型的字段,InnoDB中必须包含只有该字段的索引,但是在MyISAM表中,可以和其他字段一起建立联合索引。
 
  DELETE FROM table时,InnoDB不会重新建立表,而是一行一行的删除。
 
  LOAD TABLE FROM MASTER操作对InnoDB是不起作用的,解决方法是首先把InnoDB表改成MyISAM表,导入数据后再改成InnoDB表,但是对于使用的额外的InnoDB特性(例如外键)的表不适用。
 
  性能比较
 
  来替代我们的MyISAM引擎。
 
   ) ENGINE=InnoDB DEFAULT CHARSET=gbk;
  数据内容:
 
  $name = "heiyeluren";
 
  $content = "MySQL支持数个存储引擎作为对不同表的类型的处理器。MySQL存储引擎包括处理事务安全表的引擎和处理非事务安全表的引擎:· MyISAM管理非事务表。它提供高速存储和检索,以及全文搜索能力。MyISAM在所有MySQL配置里被支持,它是默认的存储引擎,除非你配置MySQL默认使用另外一个引擎。 ·MEMORY存储引擎提供“内存中”表。MERGE存储引擎允许集合将被处理同样的MyISAM表作为一个单独的表。就像MyISAM一样,MEMORY和MERGE存储引擎处理非事务表,这两个引擎也都被默认包含在MySQL中.
 
  释:MEMORY存储引擎正式地被确定为HEAP引擎,· InnoDB和BDB存储引擎提供事务安全表。BDB被包含在为支持它的操作系统发布的MySQL-Max二进制分发版里。InnoDB也默认被包括在所有MySQL 5.1二进制分发版里,你可以按照喜好通过配置MySQL来允许或禁止任一引擎。·EXAMPLE存储引擎是一个“存根”引擎,它不做什么。你可以用这个引擎创建表,但没有数据被存储于其中或从其中检索。这个引擎的目的是服务,在MySQL源代码中的一个例子,它演示说明如何开始编写新存储引擎。同样,它的主要兴趣是对开发者。";代码如下:
 
  [插入数据-1] (innodb_flush_log_at_trx_commit=1)
  MyISAM 1W:3/s
  InnoDB 1W:219/s
  MyISAM 10W:29/s
   InnoDB 100W:607/s
  [插入数据4] (innodb_buffer_pool_size=256M, innodb_flush_log_at_trx_commit=1, set autocommit=0)
  InnoDB 1W:3/s
  InnoDB 10W:26/s
  InnoDB 100W:379/s
  [MySQL 配置文件] (缺省配置)代码如下:
 
  # MySQL Server Instance Configuration File
  [client]
  port=3306
  [mysql]
  default-character-set=gbk
  [mysqld]
  port=3306
  basedir="C:/mysql50/"
  datadir="C:/mysql50/Data/"
  default-character-set=gbk
  default-storage-engine=INNODB
  sql-mode="STRICT_TRANS_TABLES,NO_AUTO_CREATE_USER,NO_ENGINE_SUBSTITUTION"
  max_connections=100
  query_cache_size=0
  table_cache=256
  tmp_table_size=50M
  thread_cache_size=8
  myisam_max_sort_file_size=100G
  myisam_max_extra_sort_file_size=100G
  myisam_sort_buffer_size=100M
  key_buffer_size=82M
  read_buffer_size=64K
  read_rnd_buffer_size=256K
  sort_buffer_size=256K
  innodb_additional_mem_pool_size=4M
  innodb_flush_log_at_trx_commit=1
  innodb_log_buffer_size=2M
  innodb_buffer_pool_size=159M
  innodb_log_file_size=80M
  innodb_thread_concurrency=8

(编辑:常州站长网)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    热点阅读