MySQL搜索引擎

本文源自转载

MySQL支持的存储引擎通过客户端命令:show engines来查找,支持的存储类型有8种,其中主要有以下几个:

     1.MyISAM

    2.InnoDB

    3.MEMORY

    4.MERGE

   5.ARCHIVE(5.5版本后才支持的引擎)

MyISAM表是独立于操作系统的,这说明可以轻松地将其从Windows服务器移植到Linux服务器;每当我们建立一个MyISAM引擎的表时,

就会在本地磁盘上建立三个文件,文件名就是表明。例如,我建立了一个MyISAM引擎的tb_Demo表,那么就会生成以下三个文件:

1.tb_demo.frm,存储表定义;

2.tb_demo.MYD,存储数据;

3.tb_demo.MYI,存储索引。

MyISAM表无法处理事务,这就意味着有事务处理需求的表,不能使用MyISAM存储引擎。MyISAM存储引擎特别适合在以下几种情况下使用:

1.选择密集型的表。MyISAM存储引擎在筛选大量数据时非常迅速,这是它最突出的优点。

2.插入密集型的表。MyISAM的并发插入特性允许同时选择和插入数据。例如:MyISAM存储引擎很适合管理邮件或Web服务器日志数据。

InnoDB是默认支持的存储引擎,一个健壮的事务型存储引擎,这种存储引擎已经被很多互联网公司使用,为用户操作非常大的数据存储提供了一个强大的解决方案。

InnoDB还引入了行级锁定和外键约束,在以下场合下,使用InnoDB是最理想的选择:

1.更新密集的表。InnoDB存储引擎特别适合处理多重并发的更新请求。

2.事务。InnoDB存储引擎是支持事务的标准MySQL存储引擎。

3.自动灾难恢复。与其它存储引擎不同,InnoDB表能够自动从灾难中恢复。

4.外键约束。MySQL支持外键的存储引擎只有InnoDB。

5.支持自动增加列AUTO_INCREMENT属性。

一般来说,如果需要事务支持,并且有较高的并发读取频率,InnoDB是不错的选择。使用MySQL Memory存储引擎的出发点是速度。为得到最快的响应时间,采用的逻辑存储介质是系统内存。虽然在内存中存储表数据确实会提供很高的性能,

但当mysqld守护进程崩溃时,所有的Memory数据都会丢失。获得速度的同时也带来了一些缺陷。它要求存储在Memory数据表里的数据使用的是长度不变的格式,

这意味着不能使用BLOB和TEXT这样的长度可变的数据类型,VARCHAR是一种长度可变的类型,但因为它在MySQL内部当做长度固定不变的CHAR类型,所以可以使用。

一般在以下几种情况下使用Memory存储引擎:

1.目标数据较小,而且被非常频繁地访问。在内存中存放数据,所以会造成内存的使用,可以通过参数max_heap_table_size控制Memory表的大小,设置此参数,就可以限制Memory表的最大大小。

2.如果数据是临时的,而且要求必须立即可用,那么就可以存放在内存表中。

3.存储在Memory表中的数据如果突然丢失,不会对应用服务产生实质的负面影响。

Memory同时支持散列索引和B树索引。

MERGE存储引擎是一组MyISAM表的组合,这些MyISAM表结构必须完全相同,尽管其使用不如其它引擎突出,但是在某些情况下非常有用。

说白了,Merge表就是几个相同MyISAM表的聚合器;Merge表中并没有数据,对Merge类型的表可以进行查询、更新、删除操作,这些操作实际上是对内部的MyISAM表进行操作。

Merge存储引擎的使用场景。

对于服务器日志这种信息,一般常用的存储策略是将数据分成很多表,每个名称与特定的时间端相关。例如:可以用12个相同的表来存储服务器日志数据,每个表用对应各个月份的名字来命名

当有必要基于所有12个日志表的数据来生成报表,这意味着需要编写并更新多表查询,以反映这些表中的信息。

与其编写这些可能出现错误的查询,不如将这些表合并起来使用一条查询,之后再删除Merge表,

而不影响原来的数据,删除Merge表只是删除Merge表的定义,对内部的表没有任何影响。

 

Archive是归档的意思,在归档之后很多的高级功能就不再支持了,仅仅支持最基本的插入和查询两种功能。

在MySQL 5.5版以前,Archive是不支持索引,但是在MySQL 5.5以后的版本中就开始支持索引了。Archive拥有很好的压缩机制,它使用zlib压缩库,在记录被请求时会实时压缩,所以它经常被用来当做仓库使用

 

如何选择合适的存储引擎?

(1)是否需要支持事务;

(2)是否需要使用热备;

(3)崩溃恢复:能否接受崩溃;

(4)是否需要外键支持;

然后按照标准,选择对应的存储引擎即可。

转载于:https://my.oschina.net/jaffine/blog/1575154

MySQL有两种主要的搜索引擎,分别是MyISAM和InnoDB。MyISAM是MySQL的默认引擎,它适用于读取频繁的应用场景,例如数据仓库和报表生成。MyISAM的优点是速度快,但不支持事务和行级锁定。另一方面,InnoDB是一种支持事务和行级锁定的引擎,适用于需要高并发和数据完整性的应用场景,例如电子商务和在线交易系统。InnoDB的优点是支持事务处理和外键约束,但相对于MyISAM,它的读取速度稍慢一些。因此,在选择MySQL搜索引擎时,需要根据具体的应用需求来进行选择。\[1\] 在MySQL中,主索引是用PRIMARY关键字进行标识的,一般是数据表的主键字段。如果在InnoDB引擎中删除了数据表的主索引,那么数据表将自动选择一个非空且带有唯一约束的字段作为主索引。如果没有找到符合条件的字段,InnoDB引擎将使用一个隐含字段作为主索引(ROWID)。此外,MySQL还支持非主索引,也称为辅助索引或二级索引,用于加快查询速度。\[2\] 对于MyISAM引擎,可以使用myisampack命令进行手动压缩。该命令可以将MyISAM表的索引文件进行压缩,从而减小磁盘占用空间。例如,可以使用以下命令将一个MyISAM表的索引文件从57K压缩到16K:myisampack E:\5-mysqls\mysql_1\mysql-5.6.26-winx64\data\test\test.MYI。\[3\] #### 引用[.reference_title] - *1* *3* [Mysql搜索引擎及索引的选择](https://blog.csdn.net/weixin_37481769/article/details/84789596)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^insert_down28v1,239^v3^insert_chatgpt"}} ] [.reference_item] - *2* [mysql-Innodb解析](https://blog.csdn.net/gejiangbo222/article/details/127898431)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^insert_down28v1,239^v3^insert_chatgpt"}} ] [.reference_item] [ .reference_list ]
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值