MySQL 臨時表在我們需要儲存一些臨時資料時是非常有用的。臨時表隻在目前連接配接可見,當關閉連接配接時,Mysql會自動删除表并釋放所有空間。
臨時表在MySQL 3.23版本中添加,如果你的MySQL版本低于 3.23版本就無法使用MySQL的臨時表。不過現在一般很少有再使用這麼低版本的MySQL資料庫服務了。
MySQL臨時表隻在目前連接配接可見,如果你使用PHP腳本來建立MySQL臨時表,那每當PHP腳本執行完成後,該臨時表也會自動銷毀。
如果你使用了其他MySQL用戶端程式連接配接MySQL資料庫伺服器來建立臨時表,那麼隻有在關閉用戶端程式時才會銷毀臨時表,當然你也可以手動銷毀。
執行個體
以下展示了使用MySQL 臨時表的簡單執行個體,以下的SQL代碼可以适用于PHP腳本的mysql_query()函數。
mysql> CREATE TEMPORARY TABLE SalesSummary (
-> product_name VARCHAR(50) NOT NULL
-> , total_sales DECIMAL(12,2) NOT NULL DEFAULT 0.00
-> , avg_unit_price DECIMAL(7,2) NOT NULL DEFAULT 0.00
-> , total_units_sold INT UNSIGNED NOT NULL DEFAULT 0
);
Query OK, 0 rows affected (0.00 sec)
mysql> INSERT INTO SalesSummary
-> (product_name, total_sales, avg_unit_price, total_units_sold)
-> VALUES
-> ('cucumber', 100.25, 90, 2);
mysql> SELECT * FROM SalesSummary;
+--------------+-------------+----------------+------------------+
| product_name | total_sales | avg_unit_price | total_units_sold |
+--------------+-------------+----------------+------------------+
| cucumber | 100.25 | 90.00 | 2 |
+--------------+-------------+----------------+------------------+
1 row in set (0.00 sec)
當你使用 SHOW TABLES指令顯示資料表清單時,你将無法看到 SalesSummary表。
如果你退出目前MySQL會話,再使用 SELECT指令來讀取原先建立的臨時表資料,那你會發現資料庫中沒有該表的存在,因為在你退出時該臨時表已經被銷毀了。
删除MySQL 臨時表
預設情況下,當你斷開與資料庫的連接配接後,臨時表就會自動被銷毀。當然你也可以在目前MySQL會話使用 DROP TABLE 指令來手動删除臨時表。
以下是手動删除臨時表的執行個體:
mysql> CREATE TEMPORARY TABLE SalesSummary (
-> product_name VARCHAR(50) NOT NULL
-> , total_sales DECIMAL(12,2) NOT NULL DEFAULT 0.00
-> , avg_unit_price DECIMAL(7,2) NOT NULL DEFAULT 0.00
-> , total_units_sold INT UNSIGNED NOT NULL DEFAULT 0
);
Query OK, 0 rows affected (0.00 sec)
mysql> INSERT INTO SalesSummary
-> (product_name, total_sales, avg_unit_price, total_units_sold)
-> VALUES
-> ('cucumber', 100.25, 90, 2);
mysql> SELECT * FROM SalesSummary;
+--------------+-------------+----------------+------------------+
| product_name | total_sales | avg_unit_price | total_units_sold |
+--------------+-------------+----------------+------------------+
| cucumber | 100.25 | 90.00 | 2 |
+--------------+-------------+----------------+------------------+
1 row in set (0.00 sec)
mysql> DROP TABLE SalesSummary;
mysql> SELECT * FROM SalesSummary;
ERROR 1146: Table 'RUNOOB.SalesSummary' doesn't exist