mysql常用存储引擎

阅读更多

MySQL有多种存储引擎:MyISAMInnoDBMERGEMEMORY(HEAP)BDB(BerkeleyDB)EXAMPLEFEDERATEDARCHIVECSVBLACKHOLE。可以在MySQL的操作界面上输入 ' SHOW ENGINES;'对本机的MySQL 所支持的引擎进行查询. 

    1 .  MyISAM : 管理非事务表

    它提供高速存储和检索,以及全文搜索能力。MyISAM在所有MySQL配置里被支持,它是默认的存储引擎,除非你配置MySQL默认使用另外一个引擎。

    2 .  InnoDBBDB存储引擎 : 提供事务安全表。

    BDB被包含在为支持它的操作系统发布的MySQL-Max二进制分发版里。InnoDB也默认被包括在所 MySQL 5.1二进制分发版里,你可以按照喜好通过配置MySQL来允许或禁止任一引擎。

    3 .  MEMORY存储引擎 ' 提供内存中

    MERGE存储引擎允许集合将被处理同样的MyISAM表作为一个单独的表。就像MyISAM一样,MEMORYMERGE存储引擎处理非事务表,这两个引擎也都被默认包含在MySQL中。

    4 .  EXAMPLE存储引擎 : 一个存根引擎,它不做什么

    你可以用这个引擎创建表,但没有数据被存储于其中或从其中检索。这个引擎的目的是服务,在 MySQL源代码中的一个例子,它演示说明如何开始编写新存储引擎。同样,它的主要兴趣是对开发者

    5 . NDB Cluster是被MySQL Cluster用来实现分割到多台计算机上的表的存储引擎。它在MySQL-Max 5.1二进制分发版里提供

    6 . ARCHIVE存储引擎被用来无索引地,非常小地覆盖存储的大量数据

    7 . CSV存储引擎把数据以逗号分隔的格式存储在文本文件中

    8 .  BLACKHOLE存储引擎接受但不存储数据,并且检索总是返回一个空集

    9 . FEDERATED存储引擎 : 把数据存在远程数据库中

    在MySQL 5.1中,它只和MySQL一起工作,使用MySQL C Client API。在分发中,我们想要让它使用其它驱动器或客户端连接方法连接到另外的数据源。

    当你创建一个新表的时候,你可以通过添加一个ENGINE TYPE 选项到CREATE TABLE语句来告诉MySQL你要创建什么类型的表:  CREATE TABLE students (id int(11) NOT NULL PREMARY KEY AUTO_INCREMENT , name char(8) NOT NULL , grade char(2) ) ENGINE = INNODB;

    在开发应用当中:

     MyISAM是默认的MySQL插件式存储引擎,它是在Web、数据仓储和其他应用环境下最常使用的存储引擎之一。注意,通过更改STORAGE_ENGINE配置变量,能够方便地更改MySQL服务器的默认存储引擎。

    InnoDB:用于事务处理应用程序,具有众多特性,包括ACID事务支持。

    BDB:可替代InnoDB的事务引擎,支持COMMITROLLBACK和其他事务特性。

    Memory:将所有数据保存在RAM中,在需要快速查找引用和其他类似数据的环境下,可提供极快的访问。

    Merge:允许MySQL DBA或开发人员将一系列等同的MyISAM表以逻辑方式组合在一起,并作为1个对象引用它们。对于诸如数据仓储等VLDB环境十分适合。

    Archive:为大量很少引用的历史、归档、或安全审计信息的存储和检索提供了完美的解决方案。Federated:能够将多个分离的MySQL服务器链接起来,从多个物理服务器创建一个逻辑数据库。十分适合于分布式环境或数据集市环境。

    Cluster/NDBMySQL的簇式数据库引擎,尤其适合于具有高性能查找要求的应用程序,这类查找需求还要求具有最高的正常工作时间和可用性。

    其他存储引擎包括CSV(引用由逗号隔开的用作数据库表的文件)Blackhole(用于临时禁止对数据库的应用程序输入),以及Example引擎(可为快速创建定制的插件式存储引擎提供帮助)

    注意 : 对于整个服务器或方案,你并不一定要使用相同的存储引擎,你可以为方案中的每个表使用不同的存储引擎,这点很重要。

官方介绍:http://dev.mysql.com/doc/refman/5.1/zh/storage-engines.html



 

 

你可能感兴趣的:(MySQL,搜索引擎,应用服务器,全文检索,配置管理)