MySql学习笔记07——存储引擎介绍

本文介绍了MySQL中不同存储引擎如InnoDB、MyISAM和MEMORY的特点,包括数据存储方式、事务支持、索引机制和安全性。InnoDB是默认引擎,支持事务;MyISAM速度快但不支持事务;MEMORY在内存中存储,适合快速查询但不持久化。
摘要由CSDN通过智能技术生成

存储引擎

Mysql中特有的术语,Oracle中没有。

存储引擎就是一个表存储/组织数据的方式。不同的存储引擎,表存储数据的方式不同。

指定存储引擎

在建表的时候可以在最后小括号的")"的右边使用:
ENGINE来指定存储引擎。
CHARSET来指定这张表的字符编码方式。

mysql默认的存储引擎是:InnoDB
mysql默认的字符编码方式是:utf8

建表时指定存储引擎,以及字符编码方式。
    create table t_product(
        id int primary key,
        name varchar(255)
    )engine=InnoDB default charset=gbk;

通过show create table 表名;就能看到表的存储引擎以及编码方式了

show create table t_product;
+-----------+----------------------------------------------------------------------------------------------------------------------------------------------+
| Table     | Create Table
                                                    |
+-----------+----------------------------------------------------------------------------------------------------------------------------------------------+
| t_product | CREATE TABLE `t_product` (
  `id` int NOT NULL,
  `name` varchar(255) DEFAULT NULL,
  PRIMARY KEY (`id`)
) ENGINE=InnoDB DEFAULT CHARSET=gbk |
+-----------+----------------------------------------------------------------------------------------------------------------------------------------------+
1 row in set (0.00 sec)

查看mysql支持哪些存储引擎

输入命令

show engines \G
*************************** 1. row ***************************
      Engine: MEMORY
     Support: YES
     Comment: Hash based, stored in memory, useful for temporary tables
Transactions: NO
          XA: NO
  Savepoints: NO
*************************** 2. row ***************************
      Engine: MRG_MYISAM
     Support: YES
     Comment: Collection of identical MyISAM tables
Transactions: NO
          XA: NO
  Savepoints: NO
*************************** 3. row ***************************
      Engine: CSV
     Support: YES
     Comment: CSV storage engine
Transactions: NO
          XA: NO
  Savepoints: NO
*************************** 4. row ***************************
      Engine: FEDERATED
     Support: NO
     Comment: Federated MySQL storage engine
Transactions: NULL
          XA: NULL
  Savepoints: NULL
*************************** 5. row ***************************
      Engine: PERFORMANCE_SCHEMA
     Support: YES
     Comment: Performance Schema
Transactions: NO
          XA: NO
  Savepoints: NO
*************************** 6. row ***************************
      Engine: MyISAM
     Support: YES
     Comment: MyISAM storage engine
Transactions: NO
          XA: NO
  Savepoints: NO
*************************** 7. row ***************************
      Engine: InnoDB
     Support: DEFAULT
     Comment: Supports transactions, row-level locking, and foreign keys
Transactions: YES
          XA: YES
  Savepoints: YES
*************************** 8. row ***************************
      Engine: BLACKHOLE
     Support: YES
     Comment: /dev/null storage engine (anything you write to it disappears)
Transactions: NO
          XA: NO
  Savepoints: NO
*************************** 9. row ***************************
      Engine: ARCHIVE
     Support: YES
     Comment: Archive storage engine
Transactions: NO
          XA: NO
  Savepoints: NO
9 rows in set (0.00 sec)

MyISAM

它管理的表具有以下特征:

  • 格式文件——存储表的结构(mytable.frm)

  • 数据文件——存储表中的内容(mytable.MYD)

  • 索引文件——存储表上索引(mytable.MYI):索引是一本书的目录,缩小扫描范围,提高查询效率的一种机制。

对于一张表来说,只要是主键,或者加有unique约束字段的,都会自动创建索引。

MyISAM存储引擎特点:

  • 可被转换为压缩、只读表来节省空间,这是这种存储引擎的优势!!!!

  • 不支持事务机制,安全性较低。

InnoDB

mysql的默认存储引擎。

InnoDB支持事务,支持数据库崩溃后的恢复机制。

	– 每个 InnoDB 表在数据库目录中以.frm 格式文件表示
	– InnoDB 表空间 tablespace 被用于存储表的内容(表空间是一个逻辑名称。表空间存储数据+索引。)
	– 提供一组用来记录事务性活动的日志文件
	– 用 COMMIT(提交)SAVEPOINTROLLBACK(回滚)支持事务处理
	– 提供全 ACID 兼容
	– 在 MySQL 服务器崩溃后提供自动恢复
	– 多版本(MVCC)和行级锁定
	– 支持外键及引用的完整性,包括级联删除和更新

MEMORY

使用 MEMORY 存储引擎的表,其数据存储在内存中,且行的长度固定,这两个特点使得 MEMORY 存储引擎非常快。

    – 在数据库目录内,每个表均以.frm 格式的文件表示。
    – 表数据及索引被存储在内存中。(目的就是快,查询快!)
    – 表级锁机制。
    – 不能包含 TEXTBLOB 字段。

这个引擎的优点就是在于查询效率极高,不需要和硬盘交互,但是也极不安全,电脑断电之后,数据就会消失,因为索引和数据都是存在内存中的。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值