设为首页 收藏本站
查看: 1049|回复: 0

[经验分享] MySQL DDL操作--------临时表存储实战

[复制链接]

尚未签到

发表于 2018-9-29 07:02:22 | 显示全部楼层 |阅读模式
  1. 背景
  * 临时表是基于会话的(session),只在当前连接可见
  * 当这个连接(会话)关闭的时候,会自动drop。
  * 两个不同的连接(会话)里使用相同的临时表名,并且相互不会冲突,或者使用已经存在的表,但不是临时表的表名。
  * 当这个临时表表名已存在表的时候,存在的表被隐藏了,如果临时表被drop,存在的表就可见了
  * 创建临时表用户必须有 create temporary table 权限。
  * Mysql 5.7之后临时表数据存储于 ibtmp1 文件中.
  2. MySQL 5.7临时表相关文件存储
  * 查看 MySQL 版本
mysql> select version();  
+-----------+
  
| version() |
  
+-----------+
  
| 5.7.18    |
  
+-----------+
  
1 row in set (0.01 sec)
  * 创建临时表 temp_1
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 插入数据
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 数据
mysql> SELECT * FROM temp_1;  
+----+---------------------------------------------+
  
| id | data                                        |
  
+----+---------------------------------------------+
  
|  1 | {"age": "25", "sex": "male", "name": "tom"} |
  
+----+---------------------------------------------+
  
1 row in set (0.00 sec)
  * 查看 temp 变量 [ 临时文件存储目录 ]
mysql> show variables like 'tmpdir';  
+---------------+-------+
  
| Variable_name | Value |
  
+---------------+-------+
  
| tmpdir        | /tmp  |
  
+---------------+-------+
  
1 row in set (0.02 sec)
  * 查看临时表结构定义文件 *.frm
  '#'开头的代表临时表结构定义文件
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 变量 [ 数据存储目录 ]
mysql> show variables like 'datadir';  
+---------------+-------------------+
  
| Variable_name | Value             |
  
+---------------+-------------------+
  
| datadir       | /data/mysql_data/ |
  
+---------------+-------------------+
  
1 row in set (0.01 sec)
  * 查看临时表表数据存储文件 ibtmp1 [ 5.7之后将临时表数据存储于ibtmp1文件中 ]
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 版本
mysql> show variables like 'version';  
+---------------+--------+
  
| Variable_name | Value  |
  
+---------------+--------+
  
| version       | 5.6.36 |
  
+---------------+--------+
  
1 row in set (0.00 sec)
  * 创建临时表 temp_1
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 插入数据
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 数据
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 变量 [ 临时文件存储目录 ]
mysql> show variables like 'tmpdir';  
+---------------+-------+
  
| Variable_name | Value |
  
+---------------+-------+
  
| tmpdir        | /tmp  |
  
+---------------+-------+
  
1 row in set (0.00 sec)
  * 查看临时表结构定义文件 *.frm和数据文件 *.ibd
  [ MySQL 5.7之前临时表所有表结构定义文件和数据文件存储在 tmpdir中  ]
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. 总结
  以需求驱动技术,技术本身没有优略之分,只有业务之分。



运维网声明 1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其承担任何法律责任,如涉及侵犯版权等问题,请您及时通知我们,我们将立即处理,联系人Email:kefu@iyunv.com,QQ:1061981298 本贴地址:https://www.yunweiku.com/thread-603462-1-1.html 上篇帖子: MySQL备份工具XtraBackup的使用 下篇帖子: 2、实现tomcat+mysql实现jps的连接
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

扫码加入运维网微信交流群X

扫码加入运维网微信交流群

扫描二维码加入运维网微信交流群,最新一手资源尽在官方微信交流群!快快加入我们吧...

扫描微信二维码查看详情

客服E-mail:kefu@iyunv.com 客服QQ:1061981298


QQ群⑦:运维网交流群⑦ QQ群⑧:运维网交流群⑧ k8s群:运维网kubernetes交流群


提醒:禁止发布任何违反国家法律、法规的言论与图片等内容;本站内容均来自个人观点与网络等信息,非本站认同之观点.


本站大部分资源是网友从网上搜集分享而来,其版权均归原作者及其网站所有,我们尊重他人的合法权益,如有内容侵犯您的合法权益,请及时与我们联系进行核实删除!



合作伙伴: 青云cloud

快速回复 返回顶部 返回列表