MYSQL general tablespace

本文涉及的产品
云数据库 RDS MySQL Serverless,0.5-2RCU 50GB
简介: --从mysql 5.7.6 开始其支持 general tablespace,其可以创建在一个相对路径或绝对路径上--A general tablespace is a shared tablespace, similar to the system 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

相关实践学习
基于CentOS快速搭建LAMP环境
本教程介绍如何搭建LAMP环境,其中LAMP分别代表Linux、Apache、MySQL和PHP。
全面了解阿里云能为你做什么
阿里云在全球各地部署高效节能的绿色数据中心,利用清洁计算为万物互联的新世界提供源源不断的能源动力,目前开服的区域包括中国(华北、华东、华南、香港)、新加坡、美国(美东、美西)、欧洲、中东、澳大利亚、日本。目前阿里云的产品涵盖弹性计算、数据库、存储与CDN、分析与搜索、云通信、网络、管理与监控、应用服务、互联网中间件、移动服务、视频服务等。通过本课程,来了解阿里云能够为你的业务带来哪些帮助     相关的阿里云产品:云服务器ECS 云服务器 ECS(Elastic Compute Service)是一种弹性可伸缩的计算服务,助您降低 IT 成本,提升运维效率,使您更专注于核心业务创新。产品详情: https://www.aliyun.com/product/ecs
目录
相关文章
|
11月前
|
存储 SQL 关系型数据库
图文结合带你搞懂MySQL日志之General Query Log(通用查询日志)
图文结合带你搞懂MySQL日志之General Query Log(通用查询日志)
267 0
|
关系型数据库 MySQL
MySQL的General Query日志是干什么的?底层原理是什么?
MySQL的General Query日志是干什么的?底层原理是什么?
|
SQL 存储 关系型数据库
【MySQL】通用查询日志 general query log 详解
通用查询日志(general query log)用来记录用户的所有操作,包括启动和关闭MySQL服务、所有用户的连接开始时间和截止时间、发送给MySQL数据库服务器的所有SQL指令等。当我们的数据发生异常时,查看通用查询日志,还原操作时的具体场景,准确定位问题。
|
关系型数据库 MySQL 测试技术
[MySQL FAQ]系列 — 打开general log到底影响多大
[MySQL FAQ]系列 — 打开general log到底影响多大
105 0
[MySQL FAQ]系列 — 打开general log到底影响多大
|
关系型数据库 MySQL 测试技术
[MySQL FAQ]系列 — 打开general log到底影响多大
[MySQL FAQ]系列 — 打开general log到底影响多大
[MySQL FAQ]系列 — 打开general log到底影响多大
|
监控 网络协议 关系型数据库
MySQL 通用查询日志(General Query Log)
    同大多数关系型数据库一样,日志文件是MySQL数据库的重要组成部分。MySQL有几种不同的日志文件,通常包括错误日志文件,二进制日志,通用日志,慢查询日志,等等。
1316 0
|
11天前
|
关系型数据库 MySQL 数据库
mysql卸载、下载、安装(window版本)
mysql卸载、下载、安装(window版本)
|
1月前
|
关系型数据库 MySQL 数据库连接
关于MySQL-ODBC的zip包安装方法
关于MySQL-ODBC的zip包安装方法
|
29天前
|
关系型数据库 MySQL 数据库
rds安装数据库客户端工具
安装阿里云RDS的数据库客户端涉及在本地安装对应类型(如MySQL、PostgreSQL)的客户端工具。对于MySQL,可选择MySQL Command-Line Client或图形化工具如Navicat,安装后输入RDS实例的连接参数进行连接。对于PostgreSQL,可以使用`psql`命令行工具或图形化客户端如PgAdmin。首先从阿里云控制台获取连接信息,然后按照官方文档安装客户端,最后配置客户端连接以确保遵循安全指引。
82 1
|
24天前
|
Ubuntu 关系型数据库 MySQL
Ubuntu 中apt 安装MySQL数据库
Ubuntu 中apt 安装MySQL数据库
66 0