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版本下載
? 版權聲明
文章版權歸作者所有,未經允許請勿轉載。
THE END