亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

MySQL中的臨時(shí)表與內(nèi)存表

 更新時(shí)間:2024年01月31日 09:37:41   作者:pan_junbiao  
這篇文章主要介紹了MySQL中的臨時(shí)表與內(nèi)存表,具有很好的參考價(jià)值,希望對大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教

在MySQL中有三種虛擬表:臨時(shí)表、內(nèi)存表、視圖。下面簡單介紹一下臨時(shí)表和內(nèi)存表的使用。

1、臨時(shí)表

MySQL臨時(shí)表在我們需要保存一些臨時(shí)數(shù)據(jù)時(shí)是非常有用的。臨時(shí)表在MySQL 3.23版本中添加。

臨時(shí)表只在當(dāng)前連接可見,當(dāng)關(guān)閉連接時(shí),Mysql會(huì)自動(dòng)刪除表并釋放所有空間。

如果你使用了其他MySQL客戶端程序連接MySQL數(shù)據(jù)庫服務(wù)器來創(chuàng)建臨時(shí)表,那么只有在關(guān)閉客戶端程序時(shí)才會(huì)銷毀臨時(shí)表,當(dāng)然你也可以手動(dòng)銷毀。

1.1 創(chuàng)建臨時(shí)表

在MySQL中創(chuàng)建臨時(shí)表使用CREATE TEMPORARY TABLE語句,其語法格式如下:

CREATE TEMPORARY TABLE [IF NOT EXISTS] 臨時(shí)表名
(
	...
);

示例:

創(chuàng)建臨時(shí)表。

CREATE TEMPORARY TABLE IF NOT EXISTS temp_user
(
	id INT NOT NULL DEFAULT 0,
	name VARCHAR(10) NOT NULL
);

還可以通過復(fù)制表的方式來創(chuàng)建臨時(shí)表。

示例:

通過復(fù)制表的方式來創(chuàng)建臨時(shí)表。

CREATE TEMPORARY TABLE temp_user
AS SELECT * FROM tb_user;

1.2 刪除臨時(shí)表

默認(rèn)情況下,當(dāng)你斷開與數(shù)據(jù)庫的連接后,臨時(shí)表就會(huì)自動(dòng)被銷毀。

當(dāng)然你也可以在當(dāng)前MySQL會(huì)話中手動(dòng)刪除臨時(shí)表。

刪除臨時(shí)表與刪除普通表的語句是一樣的,使用 DROP TABLE語句。

示例:

刪除臨時(shí)表。

DROP TABLE IF EXISTS temp_user;

1.3 使用臨時(shí)表的注意事項(xiàng)

(1)臨時(shí)表只在當(dāng)前連接可見,當(dāng)這個(gè)連接關(guān)閉的時(shí)候,會(huì)自動(dòng)drop。比如打開mysql 就是一個(gè)連接會(huì)話。兩個(gè)不同的連接可以使用相同名字的臨時(shí)表,兩個(gè)表之間不存在什么關(guān)系,如果臨時(shí)表的名字和已經(jīng)存在的磁盤表名字一樣,那么臨時(shí)表會(huì)暫時(shí)覆蓋磁盤表。就是說,你select 查詢,只會(huì)顯示臨時(shí)表里面的,不會(huì)顯示磁盤表。

(2)臨時(shí)表的存儲引擎:memor,myisam,merge,innodb,臨時(shí)表不支持mysql cluster簇。

(3)同一個(gè)查詢語句,只能用一次臨時(shí)表,就是說不能將表和自己做連接等。

(4)重命名表,不能用rename 可以用alter table代替。

(5)如果超出了臨時(shí)表的容量,臨時(shí)表會(huì)轉(zhuǎn)換成磁盤表。

(6)show tables語句不會(huì)列出臨時(shí)表,在information_schema中也不存在臨時(shí)表信息,show create table可以查看臨時(shí)表。

2、內(nèi)存表

內(nèi)存表的表結(jié)構(gòu)建立在磁盤里面,數(shù)據(jù)放在內(nèi)存里面;

當(dāng)MySQL斷開當(dāng)前連接后,臨時(shí)表的表結(jié)構(gòu)和表數(shù)據(jù)都沒了,但內(nèi)存表的表結(jié)構(gòu)和表數(shù)據(jù)都存在;

當(dāng)MySQL服務(wù)重啟之后,內(nèi)存表的數(shù)據(jù)會(huì)丟失,但表結(jié)構(gòu)依舊存。

2.1 創(chuàng)建內(nèi)存表

創(chuàng)建內(nèi)存表與創(chuàng)建普通表一樣,使用CREATE TABLE語句,但需要將存儲引擎設(shè)置為:ENGINE = MEMORY。

其語法格式如下:

CREATE TABLE [IF NOT EXISTS]  內(nèi)存表名
(
	...
) ENGINE = MEMORY;

示例:

創(chuàng)建內(nèi)存表。

CREATE TABLE IF NOT EXISTS tmp_table (
	id INT NOT NULL DEFAULT 0,
	name VARCHAR(10) NOT NULL
) ENGINE = MEMORY; 

2.2 刪除內(nèi)存表

刪除內(nèi)存表與刪除普通表的語句是一樣的,使用 DROP TABLE語句。

示例:

刪除內(nèi)存表。

DROP TABLE IF EXISTS tmp_table;

2.3 使用內(nèi)存表的注意事項(xiàng)

(1)當(dāng)MySQL服務(wù)重啟之后,內(nèi)存表的數(shù)據(jù)會(huì)丟失,表結(jié)構(gòu)依舊存。

(2)多個(gè)session,創(chuàng)建表的名字不能一樣。

(3)一個(gè)session創(chuàng)建會(huì)話后,對其他session也是可見的。

(4)data目錄下只有tmp_memory.frm,表結(jié)構(gòu)放在磁盤上,數(shù)據(jù)放在內(nèi)存中。

(5)可以創(chuàng)建索引,刪除索引,支持唯一索引。

(6)不影響主備,主庫上插入的數(shù)據(jù),備庫也可以查到。

(7)show tables 語句可以查看得到表。

(8)內(nèi)存表不能包含BLOB或者TEXT列。

(9)內(nèi)存表支持AUTO_INCREMENT列。

3、臨時(shí)表與內(nèi)存表區(qū)別

臨時(shí)表內(nèi)存表
存儲表結(jié)構(gòu)和數(shù)據(jù)都存儲在內(nèi)存中表結(jié)構(gòu)存儲在磁盤中,表數(shù)據(jù)存儲在內(nèi)存中
會(huì)話單個(gè)會(huì)話獨(dú)享的,是會(huì)話級別的可以多個(gè)會(huì)話共享
引擎臨時(shí)表默認(rèn),myisam內(nèi)存表默認(rèn),memory
斷開連接表結(jié)構(gòu)和表數(shù)據(jù)都沒了表結(jié)構(gòu)和表數(shù)據(jù)都存在
服務(wù)重啟表結(jié)構(gòu)和表數(shù)據(jù)都沒了表結(jié)構(gòu)存在,表數(shù)據(jù)不存在
性能由于表數(shù)據(jù)都是存放在內(nèi)存中,所以相對來說,查詢速度較快,但是數(shù)據(jù)的維護(hù)較為困難

總結(jié)

以上為個(gè)人經(jīng)驗(yàn),希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。

相關(guān)文章

最新評論