mysql的事务存储save_什么是存储引擎(Save Engines)?

存储引擎说白了就是如何存储数据、如何为存储的数据建立索引和如何更新、查询数据等技术的实现方法。因为在关系数据库中数据的存储是以表的形式存储的,所以存储引擎也可以称为表类型(即存储和操作此表的类型)。

在Oracle 和SQL Server等数据库中只有一种存储引擎,所有数据存储管理机制都是一样的。而MySql数据库提供了多种存储引擎。用户可以根据不同的需求为数据表选择不同的存储引擎,用户也可以根据自己的需要编写自己的存储引擎。

1、MySql中有哪些存储引擎?MyISAM:这种引擎是mysql最早提供的。这种引擎又可以分为静态MyISAM、动态MyISAM 和压缩MyISAM三种,不管是何种MyISAM表,目前它都不支持事务,行级锁和外键约束的功能。

MyISAM Merge引擎:这种类型是MyISAM类型的一种变种。合并表是将几个相同的MyISAM表合并为一个虚表。常应用于日志和数据仓库。

InnoDB:InnoDB表类型可以看作是对MyISAM的进一步更新产品,它提供了事务、行级锁机制和外键约束的功能,也是目前MySQL默认的存储引擎。

Memory(heap):这种类型的数据表只存在于内存中。它使用散列索引,所以数据的存取速度非常快。因为是存在于内存中,所以这种类型常应用于临时表中。

archive:这种类型只支持select 和 insert语句,而且不支持索引。常应用于日志记录和聚合分析方面。

当然MySql支持的表类型不止上面几种。下面我们介绍一下如何查看和设置数据表类型。

2、存储引擎的操作

查看数据库可以支持的存储引擎,用show engines; 命令可以显示当前数据库支持的存储引擎情况:

-- 查询 MySQL 支持的存储引擎SHOW ENGINES\G;-- 查询结果(省略的结果)***************************[ 2. row ]***************************Engine | MEMORYSupport | YESComment | Hash based, stored in memory, useful for temporary tablesTransactions | NOXA | NOSavepoints | NO***************************[ 5. row ]***************************Engine | MyISAMSupport | YESComment | MyISAM storage engineTransactions | NOXA | NOSavepoints | NO........

MySQL 从5.0 开始默认的存储引擎是 InnoDB,这一点可以通过系统变量 ​default_storage_engine​ 查询到系统默认的存储引擎。

mysql root@localhost:sakila> show variables like 'default_storage_engine';+------------------------+--------+| Variable_name | Value |+------------------------+--------+| default_storage_engine | InnoDB |+------------------------+--------+

存储引擎是基于表的,因此可以在创建的时候指定存储引擎。

-- 创建表的时候指定存储引擎,默认是 InnoDBCREATE TABLE test_table(id int primary key auto_increment,name varchar(128) NOT NULL)ENGINE = MyISAM;

3、各个存储引擎的特征

不同的存储引擎有着不同的特征,有的支持事务,有的不支持事务,因此这里需要读者熟悉常用的存储引擎 InnoDB和MyISAM的区别。

73955cbbc8a1719f07e770c1383e546b.png

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值