1. 程式人生 > >MySQL DLL操作--------臨時表存儲實戰

MySQL DLL操作--------臨時表存儲實戰

mysql dba temporary

1. 背景

  * 臨時表是基於會話的(session),只在當前連接可見

* 當這個連接(會話)關閉的時候,會自動drop。

* 兩個不同的連接(會話)裏使用相同的臨時表名,並且相互不會沖突,或者使用已經存在的表,但不是臨時表的表名。

* 當這個臨時表表名已存在表的時候,存在的表被隱藏了,如果臨時表被drop,存在的表就可見了

  * 創建臨時表用戶必須有 create temporary table 權限。

* Mysql 5.7之後臨時表數據存儲於idbdata1文件中.


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. 總結


以需求驅動技術,技術本身沒有優略之分,只有業務之分。

本文出自 “sea” 博客,請務必保留此出處http://lisea.blog.51cto.com/5491873/1943417

MySQL DLL操作--------臨時表存儲實戰