首頁  >  文章  >  資料庫  >  詳解MySQL臨時表的功能及實例代碼

詳解MySQL臨時表的功能及實例代碼

零下一度
零下一度原創
2017-05-16 10:46:232171瀏覽

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 'TUTORIALS.SalesSummary' doesn't exist

【相關建議】

1. ##特別推薦「php程式設計師工具箱」V0.1版本下載

2.

 免費mysql線上影片教學

3. 

資料庫設計那些事#

以上是詳解MySQL臨時表的功能及實例代碼的詳細內容。更多資訊請關注PHP中文網其他相關文章!

陳述:
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn