博客
关于我
Mysql-存储引擎
阅读量:797 次
发布时间:2023-02-11

本文共 1726 字,大约阅读时间需要 5 分钟。

什么是存储引擎?

存储引擎是关系数据库中的核心组件,它决定了数据如何存储、如何为数据建立索引、如何更新和查询数据等技术的实现方式。在关系数据库中,数据以表的形式存储,因此存储引擎也被称为表类型。它定义了数据存储和操作的机制。

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

MySQL支持的存储引擎

MySQL默认使用InnoDB存储引擎,从MySQL 5.5.8版本开始InnoDB成为默认存储引擎。InnoDB支持事务,其设计目标主要面向在线事务处理(OLTP)应用。其特点包括:

  • 行锁设计:InnoDB使用行锁,对并发写入的数据行进行锁定。
  • 外键支持:InnoDB支持外键约束。
  • 非锁定读:默认读取操作不会产生锁,类似Oracle的读取机制。
  • MVCC:通过多版本并发控制(MVCC)实现高并发性,支持四个隔离级别。
  • 插入缓冲和二次写:优化插入性能和磁盘写入效率。
  • 聚集存储:表数据按主键顺序存储,若无主键则生成ROWID作为主键。

MyISAM存储引擎不支持事务,主要面向OLAP数据库应用。其特点包括:

  • 表锁设计:MyISAM使用表锁,对整个表进行锁定。
  • 全文索引支持:支持全文索引。
  • 不支持事务:无法处理复杂的事务操作。

NDB存储引擎是MySQL的一个集群存储引擎,采用共享没有的集群架构,提供高可用性和高扩展性。其特点包括:

  • 数据全存内存:从MySQL 5.1版本开始支持将非索引数据存放在磁盘。
  • 快速主键查找:主键查找速度极快。
  • 可在线添加数据节点:线性扩展数据库性能。

Memory存储引擎的数据完全存放在内存中,适合临时数据表和数据仓库维度表。其默认使用哈希索引,而不是B+树索引。

Infobright存储引擎以列存储为特点,适合OLAP数据仓库应用。其官方网站为http://www.infobright.org/

NTStore存储引擎由网易公司开发,目前不支持事务,但提供压缩和行级缓存功能。

BLACKHOLE存储引擎用于主备复制中的分发主库,所有插入数据都会被丢失。

使用存储引擎

方法1:建表时指定

可以在创建表时指定存储引擎:

MariaDB [db1]> create table innodb_t1(id int,name char) engine=innodb;MariaDB [db1]> create table innodb_t2(id int) engine=innodb;MariaDB [db1]> show create table innodb_t1;MariaDB [db1]> show create table innodb_t2;

方法2:在配置文件中指定默认存储引擎

/etc/my.cnf中设置:

[mysqld]default-storage-engine=INNODBinnodb_file_per_table=1

查看当前使用的存储引擎

[root@duoduo db1]# ls /var/lib/mysql/db1/db.opt  innodb_t1.frm  innodb_t1.ibd  innodb_t2.frm  innodb_t2.ibd

小练习

创建四个表,分别使用InnoDB、MyISAM、Memory、BLACKHOLE存储引擎,进行插入数据测试:

MariaDB [db1]> create table t1(id int) engine=innodb;MariaDB [db1]> create table t2(id int) engine=myisam;MariaDB [db1]> create table t3(id int) engine=memory;MariaDB [db1]> create table t4(id int) engine=blackhole;

注意:Memory存储引擎在MySQL重启或机器重启后会丢失数据,BLACKHOLE存储引擎插入数据会被丢失。

转载地址:http://qcbfk.baihongyu.com/

你可能感兴趣的文章
mysql中int、bigint、smallint 和 tinyint的区别、char和varchar的区别详细介绍
查看>>
mysql中json_extract的使用方法
查看>>
mysql中json_extract的使用方法
查看>>
mysql中kill掉所有锁表的进程
查看>>
mysql中like % %模糊查询
查看>>
MySql中mvcc学习记录
查看>>
mysql中null和空字符串的区别与问题!
查看>>
MySQL中ON DUPLICATE KEY UPDATE的介绍与使用、批量更新、存在即更新不存在则插入
查看>>
MYSQL中TINYINT的取值范围
查看>>
MySQL中UPDATE语句的神奇技巧,让你操作数据库如虎添翼!
查看>>
Mysql中varchar类型数字排序不对踩坑记录
查看>>
MySQL中一条SQL语句到底是如何执行的呢?
查看>>
MySQL中你必须知道的10件事,1.5万字!
查看>>
MySQL中使用IN()查询到底走不走索引?
查看>>
Mysql中使用存储过程插入decimal和时间数据递增的模拟数据
查看>>
MySql中关于geometry类型的数据_空的时候如何插入处理_需用null_空字符串插入会报错_Cannot get geometry object from dat---MySql工作笔记003
查看>>
mysql中出现Incorrect DECIMAL value: '0' for column '' at row -1错误解决方案
查看>>
mysql中出现Unit mysql.service could not be found 的解决方法
查看>>
mysql中出现update-alternatives: 错误: 候选项路径 /etc/mysql/mysql.cnf 不存在 dpkg: 处理软件包 mysql-server-8.0的解决方法(全)
查看>>
Mysql中各类锁的机制图文详细解析(全)
查看>>