MySQL 第十四章 存储引擎(了解)

十四、存储引擎(了解)

14.1 什么是存储引擎?

存储引擎是MySQL中特有的一个术语,其他数据库中没有(Oracle中有但不叫这名字)

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

14.2 如何给表添加/指定“存储引擎”?

# 执行下面的语句查看默认设置(在t_student数据库下)
mysql> show tables;
+--------------------+
| Tables_in_t_student|
+--------------------+
| t_class            |
| t_student          |
+--------------------+
2 rows in set (0.00 sec)

mysql> show create table t_student;
+-----------+------------------------------------------------+
| Table     | Create Table                                                                                                                                                              |
+-----------+------------------------------------------------+
| t_student | CREATE TABLE `t_student` (
  `no` int(11) DEFAULT NULL,
  `name` varchar(32) DEFAULT NULL,
  `sex` char(1) DEFAULT NULL,
  `age` int(3) DEFAULT NULL,
  `email` varchar(255) DEFAULT NULL
) ENGINE=InnoDB DEFAULT CHARSET=utf8 |
+-----------+------------------------------------------------+
1 row in set (0.01 sec)

即,在建表的时候可以在最后的小括号的 ) 后边使用:

  • ENGINE:指定存储引擎(mysql默认的存储引擎是InnoDB)
  • CHARSET:指定这张表的字符编码方式(mysql默认的字符编码方式是utf8)

下面建一张指定存储引擎以及字符编码方式的表:

# 建指定的表
mysql> create table t_product(
    -> id int primary key,
    -> name varchar(255)
    -> )engine = InnoDB default charset = gbk;
Query OK, 0 rows affected (0.01 sec)

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

14.3 如何查看MySQL支持哪些存储引擎?

命令:show engines \G
mysql> select version();
+-----------+
| version() |
+-----------+
| 5.7.19    |
+-----------+
1 row in set (0.00 sec)

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

MySQL支持九大存储引擎,当前5.7.19版本支持8个。版本不同支持情况不同。

14.4 MySQL常用存储引擎

14.4.1 InnoDB存储引擎

这是MySQL默认的存储引擎,InnoDB支持事务,支持数据库崩溃后自动恢复机制。

  • InnoDB存储引擎最大的特点:
    • 是支持事务,以保证数据的安全。
  • nnoDB存储引擎缺点:
    • 效率不是很高,并且不能压缩,不能转换为只读,不能很好的节省存储空间。
  • InnoDB存储引擎管理的表具有下列主要特征:
    • 每个 InnoDB 表在数据库目录中以.frm 格式文件表示
    • InnoDB 表空间 tablespace 被用于存储表的内容(表空间是一个逻辑名称。表空间存储 数据+索引)
    • 提供一组用来记录事务性活动的日志文件
    • 用COMMIT(提交)、SAVEPOINT 以及ROLLBACK(回滚)支持事务处理
    • 提供全 ACID 兼容
    • 在 MySQL 服务器崩溃后提供自动恢复
    • 多版本(MVCC)和行级锁定
    • 支持外键及引用的完整性,包括级联删除和更新
14.4.2MEMORY存储引擎

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

  • MEMORY存储引擎管理的表具有下列特征:
    • 在数据库目录内,每个表均以.frm 格式的文件表示
    • 表数据及索引被存储在内存中(目的就是快,查询快!)
    • 表级锁机制
    • 不能包含 TEXT 或 BLOB 字段
  • MEMORY 存储引擎以前被称为HEAP 引擎
  • MEMORY引擎优点:
    • 查询效率是最高的。不需要和硬盘交互
  • MEMORY引擎缺点:
    • 不安全,关机之后数据消失。因为数据和索引都是在内存当中
14.4.3 MyISAM存储引擎

MyISAM存储引擎管理的表具有以下特征:

  • 使用三个文件表示每个表:

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

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

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

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

  • MyISAM存储引擎特点:

    • 可被转换为压缩、只读表来节省空间
  • MyISAM存储引擎缺点:

    • 不支持事务机制,安全性低
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

ClimberCoding

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值