MySQL DDL操作--------临时表存储实战

本文涉及的产品
云数据库 RDS MySQL Serverless,0.5-2RCU 50GB
云数据库 RDS MySQL Serverless,价值2615元额度,1个月
简介:

1. 背景

  * 临时表是基于会话的(session),只在当前连接可见

   * 当这个连接(会话)关闭的时候,会自动drop。

   * 两个不同的连接(会话)里使用相同的临时表名,并且相互不会冲突,或者使用已经存在的表,但不是临时表的表名。

   * 当这个临时表表名已存在表的时候,存在的表被隐藏了,如果临时表被drop,存在的表就可见了

  * 创建临时表用户必须有 create temporary table 权限。 

   * Mysql 5.7之后临时表数据存储于 ibtmp1 文件中.


2. MySQL 5.7临时表相关文件存储

   * 查看 MySQL 版本

1
2
3
4
5
6
7
mysql>  select  version();
+-----------+
| version() |
+-----------+
| 5.7.18    |
+-----------+
1 row  in  set  (0.01 sec)


   * 创建临时表 temp_1

1
2
3
4
5
mysql> CREATE TEMPORARY TABLE temp_1(
     ->  id  BIGINT PRIMARY KEY NOT NULL  AUTO_INCREMENT,
     -> data json
     -> )ENGINE=INNODB CHARSET=utf8mb4;
Query OK, 0 rows affected (0.00 sec)


   * 对临时表 temp_1 插入数据

1
2
3
mysql> INSERT INTO temp_1 SELECT NULL, JSON_OBJECT( 'name' 'tom' 'sex' 'male' 'age' '25' );
Query OK, 1 row affected (0.02 sec)
Records: 1  Duplicates: 0  Warnings: 0


   * 查看临时表 temp_1 数据

1
2
3
4
5
6
7
mysql> SELECT * FROM temp_1;
+----+---------------------------------------------+
id  | data                                        |
+----+---------------------------------------------+
|  1 | { "age" "25" "sex" "male" "name" "tom" } |
+----+---------------------------------------------+
1 row  in  set  (0.00 sec)

   * 查看 temp 变量 [ 临时文件存储目录 ]

1
2
3
4
5
6
7
mysql> show variables like  'tmpdir' ;
+---------------+-------+
| Variable_name | Value |
+---------------+-------+
| tmpdir        |  /tmp   |
+---------------+-------+
1 row  in  set  (0.02 sec)


   * 查看临时表结构定义文件 *.frm

   '#'开头的代表临时表结构定义文件

1
2
3
4
5
mysql> system  ls  -l  /tmp
total 18
srwxrwxrwx 1 mysql mysql    0 Jun 27 20:09 mysql.sock
-rw------- 1 mysql mysql    5 Jun 27 20:09 mysql.sock.lock
-rw-r----- 1 mysql mysql 8586 Jun 27 22:41  #sql666_9_0.frm


   * 查看 datadir 变量 [ 数据存储目录 ]

1
2
3
4
5
6
7
mysql> show variables like  'datadir' ;
+---------------+-------------------+
| Variable_name | Value             |
+---------------+-------------------+
| datadir       |  /data/mysql_data/  |
+---------------+-------------------+
1 row  in  set  (0.01 sec)


  * 查看临时表表数据存储文件 ibtmp1 [ 5.7之后将临时表数据存储于ibtmp1文件中 ]

1
2
mysql> system  ls  -l  /data/mysql_data/ibtmp1
-rw-r----- 1 mysql mysql 12582912 Jun 27 22:43  /data/mysql_data/ibtmp1


3. MySQL 5.6临时表相关文件存储

  * 查看 MySQL 版本

1
2
3
4
5
6
7
mysql> show variables like  'version' ;
+---------------+--------+
| Variable_name | Value  |
+---------------+--------+
| version       | 5.6.36 |
+---------------+--------+
1 row  in  set  (0.00 sec)


   * 创建临时表 temp_1

1
2
3
4
5
6
7
mysql> CREATE TEMPORARY TABLE temp_1( 
     ->  id  BIGINT PRIMARY KEY NOT NULL AUTO_INCREMENT,
     -> name VARCHAR(32) NOT NULL,
     -> sex ENUM( 'male' 'female' ),
     -> age INT NOT NULL
     -> )ENGINE=INNODB CHARSET=utf8mb4;
Query OK, 0 rows affected (0.06 sec)


   * 对临时表 temp_1 插入数据

1
2
3
mysql> INSERT INTO temp_1 SELECT NULL,  'tom' 'male' , 22;
Query OK, 1 row affected (0.03 sec)
Records: 1  Duplicates: 0  Warnings: 0


   * 查看临时表 temp_1 数据

1
2
3
4
5
6
7
8
9
10
11
mysql> INSERT INTO temp_1 SELECT NULL,  'tom' 'male' , 22;
Query OK, 1 row affected (0.03 sec)
Records: 1  Duplicates: 0  Warnings: 0
 
mysql> SELECT * FROM temp_1;
+----+------+------+-----+
id  | name | sex  | age |
+----+------+------+-----+
|  1 | tom  | male |  22 |
+----+------+------+-----+
1 row  in  set  (0.00 sec)


   * 查看 temp 变量 [ 临时文件存储目录 ]

1
2
3
4
5
6
7
mysql> show variables like  'tmpdir' ;
+---------------+-------+
| Variable_name | Value |
+---------------+-------+
| tmpdir        |  /tmp   |
+---------------+-------+
1 row  in  set  (0.00 sec)


   * 查看临时表结构定义文件 *.frm和数据文件 *.ibd 

        [ MySQL 5.7之前临时表所有表结构定义文件和数据文件存储在 tmpdir中  ]

1
2
3
4
5
mysql> system  ls  -l  /tmp
total 116
srwxrwxrwx 1 mysql mysql     0 Jun 27 22:53 mysql.sock
-rw-rw---- 1 mysql mysql  8656 Jun 27 22:57  #sqla34_4_0.frm
-rw-rw---- 1 mysql mysql 98304 Jun 27 22:58  #sqla34_4_0.ibd


4. 总结


以需求驱动技术,技术本身没有优略之分,只有业务之分。




      本文转自asd1123509133 51CTO博客,原文链接:http://blog.51cto.com/lisea/1943417,如需转载请自行联系原作者




相关实践学习
基于CentOS快速搭建LAMP环境
本教程介绍如何搭建LAMP环境,其中LAMP分别代表Linux、Apache、MySQL和PHP。
全面了解阿里云能为你做什么
阿里云在全球各地部署高效节能的绿色数据中心,利用清洁计算为万物互联的新世界提供源源不断的能源动力,目前开服的区域包括中国(华北、华东、华南、香港)、新加坡、美国(美东、美西)、欧洲、中东、澳大利亚、日本。目前阿里云的产品涵盖弹性计算、数据库、存储与CDN、分析与搜索、云通信、网络、管理与监控、应用服务、互联网中间件、移动服务、视频服务等。通过本课程,来了解阿里云能够为你的业务带来哪些帮助     相关的阿里云产品:云服务器ECS 云服务器 ECS(Elastic Compute Service)是一种弹性可伸缩的计算服务,助您降低 IT 成本,提升运维效率,使您更专注于核心业务创新。产品详情: https://www.aliyun.com/product/ecs
相关文章
|
12天前
|
SQL 存储 关系型数据库
不允许你不知道的 MySQL 优化实战(三)
不允许你不知道的 MySQL 优化实战(三)
20 1
|
6天前
|
SQL 存储 关系型数据库
【MySQL-6】DDL的表结构的数据类型盘点&案例演示
【MySQL-6】DDL的表结构的数据类型盘点&案例演示
|
6天前
|
SQL 关系型数据库 MySQL
【MySQL-4】简述SQLの通用语法及4种基本语句介绍(DDL/DML/DQL/DCL)
【MySQL-4】简述SQLの通用语法及4种基本语句介绍(DDL/DML/DQL/DCL)
|
6天前
|
SQL 关系型数据库 MySQL
【MySQL-5】DDL的数据库操作:查询&创建&删除&使用(可cv代码+演示图)
【MySQL-5】DDL的数据库操作:查询&创建&删除&使用(可cv代码+演示图)
|
6天前
|
SQL 存储 关系型数据库
【MySQL】DDL的表操作详解:创建&查询&修改&删除
【MySQL】DDL的表操作详解:创建&查询&修改&删除
|
7天前
|
缓存 关系型数据库 MySQL
MySQL数据库性能优化实战
【4月更文挑战第30天】本文探讨了MySQL性能优化实战技巧,包括硬件与配置优化(如使用SSD、增加内存和调整配置参数)、索引优化(创建合适索引、使用复合索引及定期维护)、查询优化(避免全表扫描、减少JOIN和使用LIMIT)、分区与分片(表分区和数据库分片),以及使用缓存、定期清理数据库和监控诊断。通过这些方法,可以提升数据库性能和响应速度。
|
7天前
|
SQL DataWorks 关系型数据库
DataWorks操作报错合集之DataWorks在同步mysql时报错Code:[Framework-02],mysql里面有个json类型字段,是什么原因导致的
DataWorks是阿里云提供的一站式大数据开发与治理平台,支持数据集成、数据开发、数据服务、数据质量管理、数据安全管理等全流程数据处理。在使用DataWorks过程中,可能会遇到各种操作报错。以下是一些常见的报错情况及其可能的原因和解决方法。
26 0
|
7天前
|
关系型数据库 MySQL Java
使用shardingjdbc执行MySQL游标操作时报错
使用shardingjdbc执行MySQL游标操作时报错
|
7天前
|
存储 SQL 关系型数据库
mysql查询数据库表大小怎么操作
mysql查询数据库表大小怎么操作
|
8天前
|
SQL 关系型数据库 MySQL
使用Python的pymysql库连接MySQL,执行CRUD操作
使用Python的pymysql库连接MySQL,执行CRUD操作:安装pymysql,然后连接(host='localhost',user='root',password='yourpassword',database='yourdatabase'),创建游标。查询数据示例:`SELECT * FROM yourtable`;插入数据:`INSERT INTO yourtable...`;更新数据:`UPDATE yourtable SET...`;删除数据:`DELETE FROM yourtable WHERE...`。
19 0