mysql引擎
来源:互联网 发布:卖数据的网站 编辑:程序博客网 时间:2024/06/08 17:03
作为一名Java开发者 MySQL 经常在使用,但大多时候只用到一些基本的 增删改查
对与MySQL的一些高级功能、底层实现还不是很了解,之前在面试的时候 被问到 MySQL的引擎有哪些,各有什么优缺点 ???
我只能回答 呵呵......
下面就这个问题做个总结
资料来源 http://www.cnblogs.com/lina1006/archive/2011/04/29/2032894.html , http://www.pureweber.com/article/myisam-vs-innodb/
MySql数据库是开放源代码的关系型数据库。目前,它可以提供的功能有:支持sql语言、子查询、存储过程、触发器、视图、索引、事务、锁、外键约束和影像复制等
什么是MySQL引擎
存储引擎说白了就是如何存储数据、如何为存储的数据建立索引和如何更新、查询数据等技术的实现方法。因为在关系数据库中数据的存储是以表的形式存储的,所以存储引擎也可以称为表类型(即存储和操作此表的类型)。在Oracle 和SQL Server等数据库中只有一种存储引擎,所有数据存储管理机制都是一样的。而MySql数据库提供了多种存储引擎。用户可以根据不同的需求为数据表选择不同的存储引擎,用户也可以根据自己的需要编写自己的存储引擎。
MySQL中的引擎
1 MyISAM:这种引擎是mysql最早提供的。这种引擎又可以分为静态MyISAM、动态MyISAM 和压缩MyISAM三种:
静态MyISAM:如果数据表中的各数据列的长度都是预先固定好的,服务器将自动选择这种表类型。因为数据表中每一条记录所占用的空间都是一样的,所以这种表存取和更新的效率非常高。当数据受损时,恢复工作也比较容易做。
动态MyISAM:如果数据表中出现varchar、xxxtext或xxxBLOB字段时,服务器将自动选择这种表类型。相对于静态MyISAM,这种表存储空间比较小,但由于每条记录的长度不一,所以多次修改数据后,数据表中的数据就可能离散的存储在内存中,进而导致执行效率下降。同时,内存中也可能会出现很多碎片。因此,这种类型的表要经常用optimize table 命令或优化工具来进行碎片整理。
压缩MyISAM:以上说到的两种类型的表都可以用myisamchk工具压缩。这种类型的表进一步减小了占用的存储,但是这种表压缩之后不能再被修改。另外,因为是压缩数据,所以这种表在读取的时候要先时行解压缩。
但是,不管是何种MyISAM表,目前它都不支持事务,行级锁和外键约束的功能。
2 MyISAM Merge引擎:这种类型是MyISAM类型的一种变种。合并表是将几个相同的MyISAM表合并为一个虚表。常应用于日志和数据仓库。
3 InnoDB:InnoDB表类型可以看作是对MyISAM的进一步更新产品,它提供了事务、行级锁机制和外键约束的功能。
4 memory(heap):这种类型的数据表只存在于内存中。它使用散列索引,所以数据的存取速度非常快。因为是存在于内存中,所以这种类型常应用于临时表中。
5 archive:这种类型只支持select 和 insert语句,而且不支持索引。常应用于日志记录和聚合分析方面。
当然MySql支持的表类型不止上面几种。
MyISAM 和 InnoDB 的对比如下
对比项 MyISAM InnoDB
存储结构每张表被存放在三个文件:
- frm-表格定义
- MYD(MYData)-数据文件
- MYI(MYIndex)-索引文件
用show engines; 可以查看该数据库的所有引擎
Show create table tablename; 显示表的创建语句
show table status like ‘tablename’\G显示表的当前状态值
Alter table tableName engine =engineName 修改存储引擎
- MySQL引擎
- MYSQL引擎
- MySQL引擎
- Mysql引擎
- MySQL引擎
- MySQL引擎
- MySQL引擎
- MYSQL引擎
- MySQL引擎
- mysql引擎
- MySQL引擎
- mysql 引擎
- mysql引擎
- MySQl引擎
- MySql引擎
- MySQL引擎
- mysql引擎
- MYSQL引擎
- 关于新手搭建PHP环境遇到的几个问题
- UCenter与Java Web部署对接
- JS入门小代码
- 单点登录设计原理
- mybatis批量插入
- mysql引擎
- jquery easyui 中tab页添加其他页面,href与content的用法与区别
- android逆波兰表达式的应用(四)逆波兰表达式的计算实现 -----小达
- KVC 与 KVO
- [Unity3d] [图文]【寻路】 Waypoint 与 NavMesh 比较(转)
- js 学习面向对象的继承
- 使用getIdentifier()获取资源Id 通过资源名称获取资源id
- JavaScript高级编程(学习笔记)
- shell脚本