• 欢迎访问搞代码网站,推荐使用最新版火狐浏览器和Chrome浏览器访问本网站!
  • 如果您觉得本站非常有看点,那么赶紧使用Ctrl+D 收藏搞代码吧

MySQL数据库优化(一)—MySQL引擎

mysql 搞代码 4年前 (2022-01-09) 23次浏览 已收录 0个评论

一、MySQL引擎种类
(一)、InnoDB
1、InnoDB简介
InnoDB是my默认引擎,支持事务,in的数据存储在表空间(tablespace)中,通过间隙锁(next-key locking)防止幻读。
2、InnoDB特点
(1)In内部做了很多优化,in基于聚簇索引建立表,对主键查询有很高的性能。
(2)读取数据时,能够在内存中创建hash索引加速插入缓冲区,读取数据时采取可预读。
(3)支持热备份,my其他引擎不支持这一功能。
(二)、MyISAM
1、MyISAM简介
MyISAM是my5.1之前版本的默认引擎,支持全文索引、压缩、空间函数,但不支持事务及行级锁,适用于只读数据、表小可忍受修复操作的应用场景。
2、MyISAM特点
(1)MyISAM存储把表存放到两个文件中:数据文件和索引文件。
(2)MyISAM支持对整张表进行加锁,但不支持行加锁。
(3)MyISAM压缩表,针对某些不再修改的表数据,使用MyISAM将表进行压缩,以减少磁盘I/O操作,提高查询效率。
(三)、CSV
本文来源gaodai$ma#com搞$$代**码)网8 CSV引擎可以将普通的CSV文件作为Mysql表处理,在数据库运行时拷入拷出文件,另外也可将excel等形式文件转储成CSV,再通过Mysql的CSV引擎处理成mysql表类型。作为一种数据交换机制,非常实用。
(四)、Memory
Memory引擎是将所有的数据保存到内存中,不需要进行磁盘I/O,它所存储的数据主要是保存和查找数据处理时的中间数据,重启数据就清空。如果Mysql执行过程中,需要临时表来保存中间结果,内部使用的临时表便是Memory表。
(五)、NDB Cluster
NDB集群索引是mysql公司在收购了NDB数据库后开发的,支持分布式、容灾、高可用的数据库索引。
二、引擎相关操作
1、查看mysql当前版本引擎
使用命令show enginses;查看mysql引擎
5.1版本中的mysql 引擎:

5.7版本中的mysql 引擎(可通过mysql客户端执行命令查看):

2、指定mysql引擎
方法一:修改my.cnf配置文件

(1)如果不太清楚mysql的my.cnf配置文件存放位置,可通过 sudo find /-name my.cnf查找该文件路径。

(2)修改如下:

[mysqld]datadir=/var/lib/mysqlsocket=/var/lib/mysql/mysql.sockuser=mysql# Disabling symbolic-links is recommended to prevent assorted security riskssymbolic-links=0[mysqld_safe]log-error=/var/log/mysqld.logpid-file=/var/run/mysqld/mysqld.piddefault-storage-engine=MyISAM

(3)使用service mysqld start 命令,重启mysql服务;查看engine类型

2、在创建库/表时指定引擎
CREATE TABLE mytable (id int, title char(20)) ENGINE = INNODB
ALTER TABLE mytable ENGINE = MyISAM

以上就是MySQL数据库优化(一)—MySQL引擎 的内容,更多相关内容请关注搞代码(www.gaodaima.com)!


搞代码网(gaodaima.com)提供的所有资源部分来自互联网,如果有侵犯您的版权或其他权益,请说明详细缘由并提供版权或权益证明然后发送到邮箱[email protected],我们会在看到邮件的第一时间内为您处理,或直接联系QQ:872152909。本网站采用BY-NC-SA协议进行授权
转载请注明原文链接:MySQL数据库优化(一)—MySQL引擎

喜欢 (0)
[搞代码]
分享 (0)
发表我的评论
取消评论

表情 贴图 加粗 删除线 居中 斜体 签到

Hi,您需要填写昵称和邮箱!

  • 昵称 (必填)
  • 邮箱 (必填)
  • 网址