MySQL(11):存储引擎
1.存储引擎是什么?
MySQL中的数据用各种不同的技术存储在文件(或者内存)中。这些技术中的每一种技术都使用不同的存储机制、索引技巧、锁定水平并且最终提供广泛的不同的功能和能力。通过选择不同的技术,你能够获得额外的速度或者功能,从而改善你的应用的整体功能。
例如,如果你在研究大量的临时数据,你也许需要使用内存MySQL存储引擎。内存存储引擎能够在内存中存储所有的表格数据。又或者,你也许需要一个支持事务处理的数据库(以确保事务处理不成功时数据的回退能力)。
这些不同的技术以及配套的相关功能在 MySQL中被称作存储引擎(也称作表类型)。 MySQL默认配置了许多不同的存储引擎,可以预先设置或者在MySQL服务器中启用。你可以选择适用于服务器、数据库和表格的存储引擎,以便在选择如何存储你的信息、如何检索这些信息以及你需要你的数据结合什么性能和功能的时候为你提供最大的灵活性。
2.下面是MySQL数据库中常用的存储引擎:
我们发现这些存储引擎功能特性不相同,现实应用中,我们根据我们的需求选择不同的存储引擎。
3. (1)查询我们MySQL中所有的存储引擎:
show engines;(或者show engines\G)
如下图:
由上面知道MySQL数据库默认存储引擎是InnoDB(安装版MySQL默认InnoDB,免安装版为MyISAM)
也可以使用show variables like 'have%';
Variable_name参数表示存储引擎的名字,Values参数表示MySQL数据库管理系统是否支持该存储引擎,其中值YES表示支持,值NO表示不支持,值DISABLED表示支持但是没有开启。
(2)查询默认存储引擎
(3)修改默认存储引擎
手动修改:
-->1.首先打开my.ini配置文件,关于"[mysqld]"组的内容如下:
#服务器端参数配置
#SERVER SECTION
…………
[mysqld]
#服务器端的端口号
port=3306
#MySQL数据库服务器的安装目录
basedir =basedir="E:/software/PHP/mysql server 5.5.15/"
#MySQL数据库数据文件的目录
datadir="C:/ProgramData/MySQL/MySQL Server 5.5/Data/"
#MySQL服务器端的字符集
character-set-server=utf8
#MySQL服务器的存储引擎
default-storage-engine=INNODB
-->2. 如果想要修改存储引擎,只需要修改[mysqld]组中的default-storage-engine参数。即如果想设置默认存储引擎为MyISAM,只需要修改成:
default-storage-engine="MyISAM" 即可实现
-->3. 重启MySQL即可
(4). 创建表的时候定义表对应的存储引擎:
进入数据库数据文件目录,找到刚刚创建的room表,如下:
上面我们可以发现,一个默认InnoDB存储引擎,存储表格时候存在一个文件(比如这里的:user1.frm)。
一个MySIAM存储引擎,存储表格时候存在3个文件(比如这里的:room.frm,room.MYD,room.MYI)。
•对应于MySIAM存储引擎:
(1) .frm是表的结构文件
(2) .MYD是表保存数据的文件
(3) .MYI是表保存索引的文件
•对应于InnoDB存储引擎:
(1) .frm是表的结构文件
(2) ibdata1是InnoDB保存数据的文件(区别于MySIAM)
(5)InnoDB 和 MyISAM 存储引擎的区别 ?
区别1:两者保存文件 的方式不同。
MySIAM,一个表,三个文件。Tbl_name.frm(结构),Tbl_name.MYD(数据),Tbl_name.MYI(索引)。
InnoDB,一个表,一个文件。Tbl_name.frm(结构),所有的InnoDB表,都是使用相同的InnoDB存储空间(就是上面的ibdata1)在保存数据和 索引。
区别2:InnoDB不支持FULLTEXT类型的索引。
区别3:InnoDB 中不保存表的具体行数,也就是说,执行select count(*) from table时,InnoDB要扫描一遍整个表来计算有多少行,但是MyISAM只要简单的读出保存好的行数即可。注意的是,当count(*)语句包含 where条件时,两种表的操作是一样的。
区别4:.对于AUTO_INCREMENT类型的字段,InnoDB中必须包含只有该字段的索引,但是在MyISAM表中,可以和其他字段一起建立联合索引。
区别5:.DELETE FROM table时,InnoDB不会重新建立表,而是一行一行的删除。
区别6:.LOAD TABLE FROM MASTER操作对InnoDB是不起作用的,解决方法是首先把InnoDB表改成MyISAM表,导入数据后再改成InnoDB表,但是对于使用的额外的InnoDB特性(例如外键)的表不适用。
(6)选择存储引擎的依据
• 性能
• 功能
MySQL(11):存储引擎的更多相关文章
- mysql之存储引擎和文件配置
(查看系统服务,在运行里输入services.msc) 补充:将mysql做成系统服务:mysqld --install 取消:mysqld --romove 在服务中可以直接鼠标操作mysql服务的 ...
- MySQL之存储引擎(表类型)的选择
和大部分的数据库不同,MySQL中有一个存储引擎的概念,用户可以根据数据存储的需求来选择不同的存储引擎.本次博客就来介绍一下MySQL中的存储引擎.MySQL版本 5.7.19. 概述 MySQL的存 ...
- MySQL常用存储引擎功能与用法详解
本文实例讲述了MySQL常用存储引擎功能与用法. MySQL存储引擎主要有两大类: 1. 事务安全表:InnoDB.BDB. 2. 非事务安全表:MyISAM.MEMORY.MERGE.EXAMPLE ...
- MySQL-TokuDB:MySQL 高性能存储引擎:TokuDB
ylbtech-MySQL-TokuDB:MySQL 高性能存储引擎:TokuDB 1.返回顶部 1. 在安装MariaDB的时候了解到代替InnoDB的TokuDB,看简介非常的棒,这里对ToduD ...
- MySQL之四 存储引擎
1.介绍 存储引擎MySQL中的"文件系统" MySQL体系结构 InnoDB存储引擎介绍 My1SAM 和InnoDB区别 mysql MariaDB [(none)]> ...
- MYSQL的存储引擎一般只要哪些?
根据个人个人见解: MySQL的存储引擎(构成.安全.锁) Myisam:数据操作快速的一种引擎,支持全文检索.文件保存在数据库名称为目录名的 目录中,有3个文件,分别是表定义文件(.frm).数据文 ...
- MySQL常用存储引擎及如何选择
一.MySQL的存储引擎 完整的引擎说明还是看官方文档:http://dev.mysql.com/doc/refman/5.6/en/storage-engines.html 这里介绍一些主要的引擎 ...
- mysql 的存储引擎介绍
在数据库中存的就是一张张有着千丝万缕关系的表,所以表设计的好坏,将直接影响着整个数据库.而在设计表的时候,我们都会关注一个问题,使用什么存储引擎.等一下,存储引擎?什么是存储引擎? 什么是存储引擎? ...
- mysql数据库存储引擎及区别
MySQL有多种存储引擎,每种存储引擎有各自的优缺点,可以择优选择使用:MyISAM.InnoDB.MERGE.MEMORY(HEAP).BDB(BerkeleyDB).EXAMPLE.FEDERAT ...
- MySQL数据库----存储引擎
什么是存储引擎? 存储引擎说白了就是如何存储数据.如何为存储的数据建立索引和如何更新.查询数据等技术的实现方法.因为在关系数据库中数据的存储是以表的形式存储的,所以存储引擎也可以称为表类型(即存储和操 ...
随机推荐
- Ubuntu下管理员界面的切换
不同于redhat的Linux系统可以通过命令su root 简单地切换到管理员状态,ubuntn 默认是没有超级用户的,因此如需使用管理员权限可以使用以下2种方法: 1.sudo -i 此命令不需要 ...
- ASP.NET菜鸟之路之Application小例子
背景 我是一个ASP.NET菜鸟,暂时开始学习ASP.NET,在此记录下我个人敲的代码,没有多少参考价值,请看到的盆友们为我点个赞支持我一下,多谢了. Session介绍 Application对象用 ...
- php xcache 配置 使用 (转载)
xcache的使用与配置 一.安装Xcache # wget http://xcache.lighttpd.net/pub/Releases/1.3.0/xcache-1.3.0.tar.gz # t ...
- python学习第十八天 --文件操作
这一章节主要讲解文件操作及其文件读取,缓存,文件指针. 文件操作 (1)文件打开:open(filepath,filemode) filepath:要打开文件的路径 filemode:文件打开的方式 ...
- codeforces 573C Bear and Drawing
Limak is a little bear who learns to draw. People usually start with houses, fences and flowers but ...
- iphone升级ios7之后出现蓝框框一直跳的问题
问题描述:iphone升级ios7之后出现蓝框框一直跳 解决办法:设置-通用-辅助功能-切换控制-里边打开了切换控制及自动扫描,直接关闭切换控制就好了
- Fedora 19+ 启动顺序调整
首先找到Windows 8的menuentry cat /boot/grub2/grub.cfg | grep Windows 设置Windows 作为默认的启动项 grub2-set-default ...
- j2ee爬坑行之二 servlet
servlet生命周期 web容器加载servlet 类 web容器调用servlet的构造函数,初始化servlet. web容器调用servlet的init()方法.注意该方法在servlet的一 ...
- win2k,XP下用setupapi.dll自动安装Driver
win2k,XP下用setupapi.dll自动安装Driver 在驱网看到54cndr 写的这篇文章,虽然自己一直都用Installshield,但还是觉得这个也是一个很好的思路,故摘录在此. 用s ...
- TProcedure,TMethod,TNotifyEvent,TWndMethod的区别,并模拟点击按钮后发生的动作
忽然发现TProcedure和TNotifEvent的区别还挺大的: procedure TForm1.Button2Click(Sender: TObject); begin ShowMessage ...