MYSQL general tablespace

--从mysql 5.7.6 开始其支持 general tablespace,其可以创建在一个相对路径或绝对路径上
--A general tablespace is a shared tablespace, similar to the system tablespace. It can hold multiple tables,
--and supports all table row formats. General tablespaces can also be created in a location relative to or independent of the MySQL data directory

--创建表空间是必需指定数据文件名(只支持一个数据文件),且以 .db 为后缀
--the data file name must have a .ibd extension. An InnoDB general tablespace only supports a single data file

--创建表空间
CREATE TABLESPACE test_ts ADD DATAFILE '/tmp/testts.ibd' ENGINE=INNODB;

--FILE_BLOCK_SIZE只在存储压缩表时才必需,注意压缩表和非压缩表不能在同一个表空间中
--The FILE_BLOCK_SIZE setting is only required if you will use the tablespace to store compressed InnoDB tables (ROW_FORMAT=COMPRESSED).
--If FILE_BLOCK_SIZE is equal innodb_page_size, the tablespace can only contain tables with an uncompressed row format (COMPACT, REDUNDANT, and DYNAMIC row formats).
--Tables with a COMPRESSED row format have a different physical page size than uncompressed tables.
--Therefore, compressed tables cannot coexist in the same tablespace as uncompressed tables

--没有指定 FILE_BLOCK_SIZE,不能存储压缩表
mysql> CREATE TABLE t1 (c1 INT PRIMARY KEY) TABLESPACE test_ts ROW_FORMAT=COMPRESSED;
ERROR 1478 (HY000): InnoDB: Tablespace `test_ts` cannot contain a COMPRESSED table

--修改表空间属性
mysql> drop tablespace test_ts;
Query OK, 0 rows affected (0.04 sec)

mysql> CREATE TABLESPACE test_ts ADD DATAFILE '/tmp/testts.ibd' FILE_BLOCK_SIZE=8192 ENGINE=INNODB;
Query OK, 0 rows affected (0.14 sec)

mysql> CREATE TABLE t1 (c1 INT PRIMARY KEY) TABLESPACE test_ts ROW_FORMAT=COMPRESSED;
Query OK, 0 rows affected (0.71 sec)

--当表空间中有表存在时,必需先清空表,才能删除表空间
--Use DROP TABLESPACE to remove a general tablespace. All tables must be dropped from a general tablespace using DROP TABLE prior to dropping the tablespace
mysql> drop tablespace test_ts;
ERROR 1529 (HY000): Failed to drop TABLESPACE test_ts
mysql> drop table t1;
Query OK, 0 rows affected (0.25 sec)

mysql> drop tablespace test_ts;
Query OK, 0 rows affected (0.01 sec)

--Tables with a COMPRESSED row format have a different physical page size than uncompressed tables.
mysql> CREATE TABLE t2 (c1 INT PRIMARY KEY) TABLESPACE test_ts ROW_FORMAT=DYNAMIC;
ERROR 1478 (HY000): InnoDB: Tablespace `test_ts` uses block size 8192 and cannot contain a table with physical page size 16384

--If FILE_BLOCK_SIZE is equal innodb_page_size, the tablespace can only contain tables with an uncompressed row format (COMPACT, REDUNDANT, and DYNAMIC row formats)
mysql> CREATE TABLESPACE test_ts ADD DATAFILE '/tmp/testts.ibd' FILE_BLOCK_SIZE=16384 ENGINE=INNODB;
Query OK, 0 rows affected (0.09 sec)

mysql> show variables like '%page_size%';
+------------------+-------+
| Variable_name    | Value |
+------------------+-------+
| innodb_page_size | 16384 |
| large_page_size  | 0     |
+------------------+-------+

mysql> CREATE TABLE t2 (c1 INT PRIMARY KEY) TABLESPACE test_ts ROW_FORMAT=DYNAMIC;
Query OK, 0 rows affected (0.07 sec)

mysql> CREATE TABLE t1 (c1 INT PRIMARY KEY) TABLESPACE test_ts ROW_FORMAT=compressed;
ERROR 1478 (HY000): InnoDB: Tablespace `test_ts` cannot contain a COMPRESSED table

时间: 2024-08-16 21:44:11

MYSQL general tablespace的相关文章

MySQL 5.7 General Tablespace学习(r11笔记第34天)

MySQL里面的文件蛮有意思,之前大体有两个参数来做基本的控制.一个是innodb_data_file_path就是一个共享表空间,数据都往这一个文件里放,也就是ibdata1,这个文件其实角色是有重复的,undo,数据都会放在一起.ibdata1会持续增长,无法收缩.另外一个参数是innodb_file_per_table,这样一来,就成了独立表空间,通俗一些就是每一个表都有独立的文件.frm和.ibd,而且实际中使用独立表空间还是比较普遍的,对于delete的操作影响MySQL和Oracle

[MySQL5.7.6] 新的tablespace类型–general tablespace

从5.7.6开始,增加了一种新的 tablespace模式(成为general tablespace),实际上它和共享表空间比较类似:创建一个单独的ibd,ibd中包含多个表,兼容不同的格式.general tablespace没有库的概念,因此可以在多个库里建属于同一tablespace的表.   为了支持这TABLESPACE,主要做了两部分改动:Innodb层的支持,及Server层对MDL子模块的改动.   下面我们逐一从如何使用,及具体实现的角度来介绍这一新特性   创建tablesp

利用mysql general log日志找出查询次数最多的SQL句子

查询最多的sql语句 开启general log   mysql> show  variables like '%general%'; +------------------+-------------------------------------+ | Variable_name | Value | +------------------+-------------------------------------+ | general_log | OFF | | general_log_fi

MySQL · 引擎特性 · InnoDB 文件系统之文件物理结构

综述 从上层的角度来看,InnoDB层的文件,除了redo日志外,基本上具有相当统一的结构,都是固定block大小,普遍使用的btree结构来管理数据.只是针对不同的block的应用场景会分配不同的页类型.通常默认情况下,每个block的大小为 UNIV_PAGE_SIZE,在不做任何配置时值为16kb,你还可以选择在安装实例时指定一个块的block大小.对于压缩表,可以在建表时指定block size,但在内存中表现的解压页依旧为统一的页大小. 从物理文件的分类来看,有日志文件.主系统表空间文

MySQL · 引擎特性 · InnoDB文件系统管理

综述 从上层的角度来看,InnoDB层的文件,除了redo日志外,基本上具有相当统一的结构,都是固定block大小,普遍使用的btree结构来管理数据.只是针对不同的block的应用场景会分配不同的页类型.通常默认情况下,每个block的大小为UNIV_PAGE_SIZE,在不做任何配置时值为16kb,你还可以选择在安装实例时指定一个块的block大小. 对于压缩表,可以在建表时指定block size,但在内存中表现的解压页依旧为统一的页大小. 从物理文件的分类来看,有日志文件,主系统表空间文

数据库内核月报 - 2015 / 11-MySQL · 社区见闻 · OOW 2015 总结 MySQL 篇

前言 && 感想 本年度Oralce Open World会议从十月25号到29号,在美国旧金山举行.数万来自全球各地的从业人员涌入Moscone Center,见证一年一度的Oracle生态系统盛事. 本次OOW2015的主题都是围绕在Oracle Cloud,云服务应该是Oracle之后的发力点.几场Oracle CTO(前Oracle CEO)Larry的主题演讲也围绕cloud,详细阐述了Oracle Cloud的设计原则,及相关的云产品,其目标直指Amazon和Microsoft

MYSQL ERROR 1146 Table doesnt exist 解析

原创转载请注明出处 源码版本 5.7.14 在MYSQL使用innodb的时候我们有时候会看到如下报错: ERROR 1146 (42S02): Table 'test.test1bak' doesn't exist 首先总结下原因: 缺少frm文件 innodb数据字典不包含这个表 我们重点讨论情况2,因为情况1是显而易见的. ?在使用innodb存储引擎的时候某些时候我们show tables能够看到这个表,但是如果进行任何操作会报错如下: mysql> show tables; | tes

使用sysbench对mysql压力测试

sysbench是一个模块化的.跨平台.多线程基准测试工具,主要用于评估测试各种不同系统参数下的数据库负载情况.关于这个项目的详细介绍请看:https://github.com/akopytov/sysbench . 它主要包括以下几种方式的测试: cpu性能 磁盘io性能 调度程序性能 内存分配及传输速度 POSIX线程性能 数据库性能(OLTP基准测试) sysbench的数据库OLTP测试支持MySQL.PostgreSQL.Oracle,目前主要用于Linux操作系统,开源社区已经将sy

sysbench对mysql压力测试的详细教程_Mysql

前言 在对网站整体性能进行benchmark时,可以使用多种工具,比如大名鼎鼎的ab(Apache bench),http_load等工具.这里我们不关注他们的使用,如果你想了解,可以自行在网上找到答案. 重点来说MySQL的基准测试如何进行,也有很多种工具来供我们选择,比如mysqlslap.sysbench.Super Smack等,其中mysqlslap的使用MySQL官网给出了介绍,Super Smack是服务器压力测试强有力的工具,那么sysbench便是我们进行MySQL基准测试的很