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

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.“php程序員工具箱”V0.1版本下載“php程序員工具箱”V0.1版本下載

3.?“php程序員工具箱”V0.1版本下載“php程序員工具箱”V0.1版本下載

? 版權聲明
THE END
喜歡就支持一下吧
點贊6 分享