软件测试修炼之路 A Tester

MySQL-存储引擎

2016-07-19
i.itest.ren

存储引擎简介

mysql> SHOW CREATE TABLE users \G;
*************************** 1. row ***************************
       Table: users
Create Table: CREATE TABLE `users` (
  `id` smallint(5) unsigned NOT NULL AUTO_INCREMENT,
  `username` varchar(20) NOT NULL,
  `password` varchar(32) NOT NULL,
  `age` tinyint(3) unsigned NOT NULL DEFAULT '10',
  `sex` tinyint(1) DEFAULT NULL,
  PRIMARY KEY (`id`)
) ENGINE=InnoDB AUTO_INCREMENT=18 DEFAULT CHARSET=utf8
1 row in set (0.00 sec)

ERROR:
No query specified

这里的InnoDB即是存储引擎。

MySQL可以将数据以不同的技术存储在文件(内存)中,这种技术就称为存储引擎。

每一种存储引擎使用不同的存储机制、索引技巧、锁定水平,最终提供广泛且不同的功能。

MySQL支持的存储引擎:

  • MyISAM
  • InnoDB
  • Memory
  • CSV
  • Archive

相关知识点之并发处理

  • 并发控制
    • 当多个连接对记录进行修改时保证数据的一致性和完整性。
    • 共享锁(读锁):在同一时间段内,多个用户可以读取同一个资源,读取过程中数据不会发生任何变化。
    • 排它锁(写锁):在任何时间只能有一个用户写入资源,当进行写锁时会阻塞其他的读锁或者写锁操作。
  • 锁颗粒
    • 表锁,是一种开销最小的锁策略。
    • 行锁,是一种开销最大的锁策略。

相关知识点之事务处理

  • 事务
    • 事务用于保证数据库的完整性
  • 事务的特性
    • 原子性(Atomicity)
    • 一致性(Consistency)
    • 隔离性(Isolation)
    • 持久性(Durability)

相关知识点之外键和索引

  • 外键
    • 是保证数据一致性的策略。
  • 索引
    • 是对数据表中一列或多列的值进行排序的一种结构。
    • 分为普通索引、唯一索引、全文索引、btree索引、hash索引…

各种存储引擎的特点

各种存储引擎的特点

CSV是有逗号分隔的存储引擎,不支持索引。

BlackHole: 黑洞引擎,写入的数据都会消失,一般用于做数据复制的中继。

MyISAM:适用于事务的处理不多的情况。

InnoDB: 适用于事务处理比较多,需要有外键支持的情况。

设置存储引擎

修改存储引擎的方法:

  • 通过修改MySQL配置文件实现
    • default-storage-engine = engine
  • 通过创建数据表命令实现

示例:

CREATE TABLE table_name(
...
...
)ENGINE = engine;

上一篇 MySQL-存储过程

Comments