程序師世界是廣大編程愛好者互助、分享、學習的平台,程序師世界有你更精彩!
首頁
編程語言
C語言|JAVA編程
Python編程
網頁編程
ASP編程|PHP編程
JSP編程
數據庫知識
MYSQL數據庫|SqlServer數據庫
Oracle數據庫|DB2數據庫
 程式師世界 >> 數據庫知識 >> MYSQL數據庫 >> MySQL綜合教程 >> MySQL中暫時表的根本創立與應用教程

MySQL中暫時表的根本創立與應用教程

編輯:MySQL綜合教程

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 的輸出,也只能應用輪回來做。暫時表也不實用於須要三維數組的情形。

  1. 上一頁:
  2. 下一頁:
Copyright © 程式師世界 All Rights Reserved