自拍偷在线精品自拍偷,亚洲欧美中文日韩v在线观看不卡

MySQL臨時(shí)表中的Sql代碼示例

數(shù)據(jù)庫 MySQL
我們今天主要向大家講述的是MySQL臨時(shí)表具體使用的詳細(xì)講解,以及其實(shí)際操作中Sql代碼的演示,以下就是文章的具體內(nèi)容。

下面的文章主要講述的是MySQL臨時(shí)表具體使用的詳細(xì)講解,我們大家都知道當(dāng)工作在十分大表上運(yùn)行時(shí),在實(shí)際操作中你可能會(huì)需要運(yùn)行很多的相關(guān)查詢,來獲的一個(gè)大量數(shù)據(jù)的小的子集,不是對(duì)整個(gè)表運(yùn)行這些查詢。

而是讓MySQL每次找出所需的少數(shù)記錄,將記錄選擇到一個(gè)臨時(shí)表可能更快些,然后多這些表運(yùn)行查詢。

創(chuàng)建MySQL臨時(shí)表很容易,給正常的CREATE TABLE語句加上TEMPORARY關(guān)鍵字:

Sql代碼

  1. CREATE TEMPORARY TABLE tmp_table (   
  2. name VARCHAR(10) NOT NULL,   
  3. value INTEGER NOT NULL   
  4. )   
  5. CREATE TEMPORARY TABLE tmp_table (  
  6. name VARCHAR(10) NOT NULL,  
  7. value INTEGER NOT NULL  
  8. )  

 

臨時(shí)表將在你連接MySQL期間存在。當(dāng)你斷開時(shí),MySQL將自動(dòng)刪除表并釋放所用的空間。當(dāng)然你可以在仍然連接的時(shí)候刪除表并釋放空間。

 

  1. DROP TABLE tmp_table 

如果在你創(chuàng)建名為tmp_table臨時(shí)表時(shí)名為tmp_table的表在數(shù)據(jù)庫中已經(jīng)存在,MySQL臨時(shí)表將有必要屏蔽(隱藏)非臨時(shí)表tmp_table。

如果你聲明臨時(shí)表是一個(gè)HEAP表,MySQL也允許你指定在內(nèi)存中創(chuàng)建它:

Sql代碼

  1. CREATE TEMPORARY TABLE tmp_table (   
  2. name VARCHAR(10) NOT NULL,   
  3. value INTEGER NOT NULL   
  4. TYPE = HEAP   
  5. CREATE TEMPORARY TABLE tmp_table (  
  6. name VARCHAR(10) NOT NULL,  
  7. value INTEGER NOT NULL  
  8. TYPE = HEAP 

因?yàn)镠EAP表存儲(chǔ)在內(nèi)存中,你對(duì)它運(yùn)行的查詢可能比磁盤上的臨時(shí)表快些。然而,HEAP表與一般的表有些不同,且有自身的限制。詳見MySQL參考手冊(cè)。

正如前面的建議,你應(yīng)該測(cè)試臨時(shí)表看看它們是否真的比對(duì)大量數(shù)據(jù)庫運(yùn)行查詢快。如果數(shù)據(jù)很好地索引,臨時(shí)表可能一點(diǎn)不快。

1、臨時(shí)表再斷開于MySQL的連接后系統(tǒng)會(huì)自動(dòng)刪除MySQL臨時(shí)表中的數(shù)據(jù),但是這只限于用下面語句建立的表:

1)定義字段

  1. CREATE TEMPORARY TABLE tmp_table (   
  2. name VARCHAR(10) NOT NULL,   
  3. value INTEGER NOT NULL   

2)直接將查詢結(jié)果導(dǎo)入臨時(shí)表

CREATE TEMPORARY TABLE tmp_table SELECT * FROM table_name

2、另外MySQL也允許你在內(nèi)存中直接創(chuàng)建臨時(shí)表,因?yàn)槭窃趦?nèi)存中所有速度會(huì)很快,語法如下:

  1. CREATE TEMPORARY TABLE tmp_table (   
  2. name VARCHAR(10) NOT NULL,   
  3. value INTEGER NOT NULL   
  4. TYPE = HEAP  

3、從上面的分析可以看出MySQL臨時(shí)表的數(shù)據(jù)是會(huì)被清空的,你斷開了連接就會(huì)被自動(dòng)清空,但是你程序中不可能每發(fā)行一次sql就連接一次數(shù)據(jù)庫吧(如果是這樣的話,那就會(huì)出現(xiàn)你擔(dān)心的問題,如果不是就沒有問題),因?yàn)橹挥袛嚅_數(shù)據(jù)庫連接才會(huì)被清空數(shù)據(jù),在一個(gè)數(shù)據(jù)庫連接里面發(fā)行多次sql的話系統(tǒng)是不會(huì)自動(dòng)清空臨時(shí)表數(shù)據(jù)的。

【編輯推薦】

  1. MySQL SELECT使用技巧大全
  2. MySQL5.0中文問題實(shí)際解決方案
  3. MySQL修改表結(jié)構(gòu)alter 實(shí)操
  4. MySQL ALTER語法的運(yùn)用
  5. MySQLunion 語法代碼演示

 

責(zé)任編輯:佚名 來源: 互聯(lián)網(wǎng)
相關(guān)推薦

2010-03-29 17:03:48

Oracle創(chuàng)建

2011-03-29 13:22:07

SQL Server臨時(shí)表表變量

2021-04-29 08:11:11

SQL優(yōu)化作用

2010-07-01 14:11:40

SQL Server內(nèi)

2010-09-08 16:03:57

SQL臨時(shí)表數(shù)據(jù)庫

2010-10-19 14:45:01

SQL SERVER臨

2010-11-22 15:19:28

Mysql臨時(shí)表

2010-05-18 16:29:44

MySQL修改表

2010-09-16 15:03:10

SQL Server臨

2010-09-16 17:56:31

SQL server臨

2010-05-18 18:39:27

Mysql臨時(shí)表

2011-09-02 14:45:43

Oracle臨時(shí)表SQL Server臨

2010-10-19 15:25:05

Sql Server臨

2010-07-08 14:42:34

SQL Server臨

2021-01-18 05:23:14

SQL 排序Server

2010-09-16 15:10:48

SQL Server表

2009-03-18 10:56:29

生命周期全局臨時(shí)表SQL Server

2010-07-22 16:02:29

2010-10-19 15:31:40

sql server觸

2010-09-06 16:52:17

SQL函數(shù)
點(diǎn)贊
收藏

51CTO技術(shù)棧公眾號(hào)