MySQL中暫時表的根本創立與應用教程。本站提示廣大學習愛好者:(MySQL中暫時表的根本創立與應用教程)文章只能為提供參考,不一定能成為您想要的結果。以下是MySQL中暫時表的根本創立與應用教程正文
當任務在異常年夜的表上時,你能夠偶然須要運轉許多查詢取得一個年夜量數據的小的子集,不是對全部表運轉這些查詢,而是讓MySQL每次找出所需的多數記載,將記載選擇到一個暫時表能夠更快些,然後在這些表運轉查詢。
創立暫時表很輕易,給正常的CREATE TABLE語句加上TEMPORARY症結字:
CREATE TEMPORARY TABLE tmp_table ( name VARCHAR(10) NOT NULL, value INTEGER NOT NULL )
暫時表將在你銜接MySQL時代存在。當你斷開時,MySQL將主動刪除表並釋放所用的空間。固然你可以在依然銜接的時刻刪除表並釋放空間。
DROP TABLE tmp_table
假如在你創立名為tmp_table暫時表時名為tmp_table的表在數據庫中曾經存在,暫時表將有需要屏障(隱蔽)非暫時表tmp_table。
假如你聲明暫時表是一個HEAP表,MySQL也許可你指定在內存中創立它:
CREATE TEMPORARY TABLE tmp_table ( name VARCHAR(10) NOT NULL, value INTEGER NOT NULL ) TYPE = HEAP
由於HEAP表存儲在內存中,你對它運轉的查詢能夠比磁盤上的暫時表快些。但是,HEAP表與普通的表有些分歧,且有本身的限制。詳見MySQL參考手冊。
正如後面的建議,你應當測試暫時表看看它們能否真的比對年夜量數據庫運轉查詢快。假如數據很好地索引,暫時表能夠一點不快。
暫時表再斷開於mysql的銜接後體系會主動刪除暫時表中的數據,然則這只限於用上面語句樹立的表:
界說字段:
CREATE TEMPORARY TABLE tmp_table ( name VARCHAR(10) NOT NULL, value INTEGER NOT NULL )
直接將查詢成果導入暫時表
CREATE TEMPORARY TABLE tmp_table SELECT * FROM table_name
別的mysql也許可你在內存中直接創立暫時表,由於是在內存中一切速度會很快,語法以下:
CREATE TEMPORARY TABLE tmp_table ( name VARCHAR(10) NOT NULL, value INTEGER NOT NULL ) TYPE = HEAP
從下面的剖析可以看出暫時表的數據是會被清空的,你斷開了銜接就會被主動清空,然則你法式中弗成能每刊行一次sql就銜接一次數據庫吧(假如是如許的話,那就會湧現你擔憂的成績,假如不是就沒有成績),由於只要斷開數據庫銜接才會被清空數據,在一個數據庫銜接外面刊行屢次sql的話體系是不會主動清空暫時表數據的。
只要在以後銜接情形下, TEMPORARY 表才是可見的。當銜接封閉時, TEMPORARY 表被主動撤消。這意味著兩個分歧的銜接可使用雷同的暫時表稱號,同時兩個暫時表不會相互抵觸,也不與原本的同名的非暫時表抵觸。(原本的表被隱蔽,直莅臨時表被撤消時為止。)必需具有 CREATE TEMPORARY TABLES 權限,能力創立暫時表。可以經由過程指定 ENGINE|TYPE = MEMORY; 來指定創立內存暫時表。
假如表已存在,則應用症結詞 IF NOT EXISTS 可以避免產生毛病。留意,原有表的構造與 CREATE TABLE 語句中表現的表的構造能否雷同,這一點沒有驗證。正文:假如在 CREATE TABLE...SELECT 語句中應用 IF NOT EXISTS ,則豈論表能否已存在,由 SELECT 部門選擇的記載都邑被拔出。
DROP TEMPORARY TABLE 語句只撤消 TEMPORARY 表,語句不會終止正在停止中的事務。在采取銜接池的情形下,為避免屢次 CREATE 、 DROP TEMPORARY TABLE 帶來的機能瓶頸,可使用 CREATE IF NOT EXISTS + TRUNCATE TABLE 的方法來晉升機能。
暫時表支撐主鍵、索引指定。在銜接非暫時表查詢可以應用指定主鍵或索引來晉升機能。
CREATE PROCEDURE sp_test_tt(IN i_chars VARCHAR(50),OUT o_counts BIGINT) BEGIN create temporary table if not exists tmpTable – 不存在則創立暫時表 ( objChk varchar(255) primary key, ModelName varchar(50), Operator varchar(500), PModelName varchar(50) ); truncate TABLE tmpTable; -- 應用前先清空暫時表。 insert into tmpTable values(i_chars,i_chars,i_chars,i_chars); insert into tmpTable values(i_chars,i_chars,i_chars,i_chars); -- 語句1 select * from tmpTable; -- 語句2 select count(*) into o_counts from tmpTable; -- 語句3 END;
上述代碼語句 1 前往暫時表中一切數據,語句 2 將總記載數寫入輸入參數。 truncate 語句放在 create 以後,而不是全部存儲進程最初,緣由在於隨後的語句 1 拔出異樣的值,二暫時表 PK 校驗將發生一個毛病,則存儲進程終究異常停止。綜合異常處置,可以以下修正,以在每次存儲進程挪用終了後消除暫時表。
再來看一個例子:
CREATE PROCEDURE sp_test_tt(IN i_chars VARCHAR(50),OUT o_counts BIGINT) BEGIN create temporary table if not exists tmpTable ( objChk varchar(255) primary key, ModelName varchar(50), Operator varchar(500), PModelName varchar(50) ) ENGINE = MEMORY; begin declare exit handler for sqlwarning,NOT FOUND,SQLEXCEPTION set o_counts=-1; insert into tmpTable values(i_chars,i_chars,i_chars,i_chars); select * from tmpTable; -- 語句1 select count(*) into o_counts from tmpTable; end; truncate TABLE tmpTable; -- 語句2 END;
固然上述代碼語句 2 最初 truncate table 清空了全體暫時表數據,但後面語句 1 select 的數據成果集不會被消除。已經由過程 java 法式驗證。
暫時表可以處理二維數組輸入的成績。然則,年夜批量的數據拔出只能由法式采取輪回來做。某些特別情形下的輸出數組,例如選擇好的一組待刪除數據的 ID 的輸出,也只能應用輪回來做。暫時表也不實用於須要三維數組的情形。