MySQL存储结构MyISAM和InnoDB | |
|
|
来源: ChinaUnix博客 日期: 2005.12.12 14:38 (共有条评论) 我要评论 | |
MySQL两种表存储结构MyISAM和InnoDB的性能比较测试 MyISAM 表。MyISAM 存储格式自版本 3.23 以来是 MySQL 中的缺省类型,它有下列特点: ■ 如果操作系统自身允许更大的文件,那么文件比 ISAM 存储方法的大。 ■ 数据以低字节优先的机器独立格式存储。这表示可将表从一种机器拷贝到另一种机器,即使它们的体系结构不同也可以拷贝。 ■ 数值索引值占的存储空间较少,因为它们是按高字节优先存储的。索引值在低位字节中变化很快,因此高位字节更容易比较。 ■ AUTO_INCREMENT 处理比 ISAM 的表更好。详细内容在第2章讨论。 ■ 减少了几个索引限制。例如,可对含 NULL 值的列进行索引,还可以对 BLOB 和 TEXT 类型的列进行索引。 ■ 为了改善表的完整性检查,每个表都具有一个标志,在 myisamchk 对表进行过检查后,设置该标志。可利用 myisamchk - fast 跳过对自前次检查以来尚未被修改过表的检查,这样使此管理任务更快。表中还有一个指示表是否正常关闭的标志。如果服务器关闭不正常,或机器崩溃,此标志可用来检测出服务器起动时需要检查的表。 InnoDb 介绍: InnoDb 存储引擎,支持事务,行锁,外键.InnoDb 设计用来处理大数据量时提供最好的 性能. InnoDb 提供自己的缓存(buffer pool) 还缓存数据和索引.innodb 把数据和索引存放 到表空间(tablespace) ,表空间是几个磁盘文件或者是原是设备文件(raw disk). 它 不像MyISAM 存储引擎,每个表只是一个文件.(这样在某些系统下最大2G限制). 而Innodb 没有此限制,可以无限扩展. Mysql4.0 的以后版本都支持innodb 存储. InnoDb 配置: innodb 管理的两个磁盘文件是表空间文件和日志文件. 表空间定义: innodb_data_file_path=datafile_spec1[;datafile_spec2]... 文件声明格式: file_name:file_size[:autoextend[:max:max_file_size]] innodb_data_home_dir 声明文件存放目录. mysql 读取配置文件的顺序: `/etc/my.cnf' Global options. `DATADIR/my.cnf' Server-specific options. `defaults-extra-file' The file specified with the --defaults-extra-file option. `~/.my.cnf' User-specific options. 内存使用下面的加起来不要超过2G: innodb_buffer_pool_size + key_buffer_size + max_connections*(sort_buffer_size+read_buffer_size+binlog_cache_size) + max_connections*2MB InnoDb 参数说明: innodb_additional_mem_pool_size 存储数据字典信息和内部结构信息, 如果你的表越多,这个需要的内存就越多,如果你预留的空间不够,就开始象系统申请内存.errlog 会有错误. 缺省设置为1M. innodb_autoextend_increment 当表空间满时字段扩展大小. innodb_buffer_pool_size 数据和索引用的缓存大小.一般时系统物理内存的50~80% . 本文来自ChinaUnix博客,如果查看原文请点:http://blog.chinaunix.net/u/6541/showart_61105.html |
- 浏览: 865793 次
- 性别:
- 来自: 上海
最新评论
-
zzuliuli:
很实用,一直关注
mysql的执行计划 -
rxin2009:
你好,最近在解决redis数据同步的问题,找到了tedis,但 ...
taobao/tedis的redis集群 -
zhangping2056:
楼主接下来要考虑页面静态化与细节上面的东西了
Nginx与Redis解决高并发问题 -
XieFuQ:
Tomcat的重启shell脚本 -
jovinlee:
jovinlee 写道 jov ...
Tomcat的重启shell脚本
相关推荐
MyISAM存储引擎的特点是:表级锁、不支持事务和全文索引,适合一些CMS内容管理系统作为后台数据库使用,但是使用大并发、重负荷生产系统上,表锁结构的特性就显得力不从心; 以下是MySQL 5.7 MyISAM存储引擎的版本...
MySQL存储引擎MyISAM与InnoDB的区别 一、InnoDB支持事务,MyISAM不支持,这一点是非常之重要。事务是一种高级的处理方式,如在一些列增删改中只要哪个出错还可以回滚还原,而MyISAM就不可以了。 二、MyISAM适合查询...
MySQL两种表存储结构MyISAM和InnoDB的性能比较测试
8.MySQL存储引擎--MyISAM与InnoDB区别1
自己总结的 关于mysql存储引擎myisam innodb 的比较 两者区别 对面试会很有帮助
InnoDB支持事务安全、Mysq唯一支持外键的存储引擎。使用要使用事务或者外键,InnoDB成为不二的选择。 但同时InnoDB提供了两种自动提交和手动提交两种选择(SET AUTOCOMMIT=0设置),根据文档所述,自动提交的性能...
在使用MySQL的过程中对MyISAM和InnoDB这两个概念存在了些疑问,到底两者引擎有何分别一直是存在我心中的疑问。为了解开这个谜题,搜寻了网络,找到了如下信息: MyISAM是MySQL的默认数据库引擎(5.5版之前),由...
InnoDB和MyISAM是许多人在使用MySQL时最常用的两个表类型,这两个表类型各有优劣,视具体应用而定。基本的差别为:MyISAM类型不支持事务处理等高级处理,而InnoDB类型支持。MyISAM类型的表强调的是性能,其执行数度...
主要介绍了Mysql 的存储引擎,myisam和innodb的区别,需要的朋友可以参考下
本文深入对比分析了MySQL的两大存储引擎InnoDB和MyISAM之间的区别,包括事务支持、数据恢复能力、并发控制、存储空间占用和读取性能等多个维度。通过详细的技术和场景分析, objectively评估两者的优缺点,并给出选择...
mysql数据库存储引擎为MyISAM的时候,在大访问量的情况下数据表有可能会出现被锁的情况,这就会导致用户连接网站时超时而返回502,此时就需要MySQL数据库MyISAM存储引擎转为Innodb。步骤如下:1、导出CentOS数据库的...
mysql数据据存储引擎InnoDB和MyISAM的优势及区别分享.pdf
MySQL有多种存储引擎,MyISAM和InnoDB是其中常用的两种。这里介绍关于这两种引擎的一些基本概念(非深入介绍)。MyISAM是MySQL的默认存储引擎,基于传统的ISAM类型,支持全文搜索,但不是事务安全的,而且不支持外键...
主要介绍了MySQL存储引擎简介及MyISAM和InnoDB的区别,重点介绍了MyISAM 和 InnoDB的区别,需要的朋友可以参考下
2、支持的索引类型(1)BTree索引(最常见)(2)R-Tree索引(3)Full-Text索引(全文检索:MySQL中只有MyISAM存储引擎支持)(4)H