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

MySQL內(nèi)存表heap使用總結(jié)歸納

數(shù)據(jù)庫(kù) MySQL
MySQL中的內(nèi)存表使用哈希散列索引把數(shù)據(jù)保存在內(nèi)存中,因此具有極快的速度,適合緩存中小型數(shù)據(jù)庫(kù),下面就讓我們了解一些內(nèi)存表heap使用的一些知識(shí)。

MySQL內(nèi)存表相信大家都不會(huì)陌生,下面就對(duì)MySQL內(nèi)存表heap使用進(jìn)行了總結(jié)歸納,供您參考學(xué)習(xí)之用。

MySQL內(nèi)存表使用哈希散列索引把數(shù)據(jù)保存在內(nèi)存中,因此具有極快的速度,適合緩存中小型數(shù)據(jù)庫(kù),但是使用上受到一些限制。

1、heap對(duì)所有用戶的連接是可見(jiàn)的,這使得它非常適合做緩存。

2、僅適合使用的場(chǎng)合。heap不允許使用xxxTEXT和xxxBLOB數(shù)據(jù)類型;只允許使用=和<=>操作符來(lái)搜索記錄(不允許& lt;、>、<=或>=);不支持auto_increment;只允許對(duì)非空數(shù)據(jù)列進(jìn)行索引(not null)。
注:操作符 “<=>” 說(shuō)明:NULL-safe equal.這個(gè)操作符和“=”操作符執(zhí)行相同的比較操作,不過(guò)在兩個(gè)操作碼均為NULL時(shí),其所得值為1而不為NULL,而當(dāng)一個(gè)操作碼為NULL時(shí),其所得值為0而不為NULL。

3、一旦服務(wù)器重啟,所有heap表數(shù)據(jù)丟失,但是heap表結(jié)構(gòu)仍然存在,因?yàn)閔eap表結(jié)構(gòu)是存放在實(shí)際數(shù)據(jù)庫(kù)路徑下的,不會(huì)自動(dòng)刪除。重啟之后,heap將被清空,這時(shí)候?qū)eap的查詢結(jié)果都是空的。

4、如果heap是復(fù)制的某數(shù)據(jù)表,則復(fù)制之后所有主鍵、索引、自增等格式將不復(fù)存在,需要重新添加主鍵和索引,如果需要的話。

5、對(duì)于重啟造成的數(shù)據(jù)丟失,有以下的解決辦法:
a、在任何查詢之前,執(zhí)行一次簡(jiǎn)單的查詢,判斷heap表是否存在數(shù)據(jù),如果不存在,則把數(shù)據(jù)重新寫入,或者DROP表重新復(fù)制某張表。這需要多做一次查詢。不過(guò)可以寫成include文件,在需要用該heap表的頁(yè)面隨時(shí)調(diào)用,比較方便。
b、對(duì)于需要該heap表的頁(yè)面,在該頁(yè)面***次且僅在***次查詢?cè)摫頃r(shí),對(duì)數(shù)據(jù)集結(jié)果進(jìn)行判斷,如果結(jié)果為空,則需要重新寫入數(shù)據(jù)。這樣可以節(jié)省一次查詢。
c、更好的辦法是在mysql每次重新啟動(dòng)時(shí)自動(dòng)寫入數(shù)據(jù)到heap,但是需要配置服務(wù)器,過(guò)程比較復(fù)雜,通用性受到限制。
藍(lán)草目前采用的是第二種辦法。

6、一些預(yù)期可能用到的sql語(yǔ)句

//如果表存在,則刪除
DROP TABLE IF EXISTS `abc`;
//復(fù)制整張表xyz為heap表abc(包含所有數(shù)據(jù))
CREATE TABLE `abc` type=heap select * from `xyz`;
//添加主鍵id
ALTER TABLE `abc` ADD PRIMARY KEY (`id`);
//添加索引username
ALTER TABLE `abc` ADD INDEX `abc` (`username`);

 

 

【編輯推薦】

實(shí)例講解MySQL連接查詢

Mysql多表查詢的實(shí)現(xiàn)

Mysql臨時(shí)表的用法

拆表用的MySQL存儲(chǔ)過(guò)程

深入探討MySQL鎖機(jī)制

 
 

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

2010-05-24 10:42:33

MySQL heap

2009-10-29 13:34:01

ADO.NET對(duì)象

2010-05-27 10:50:11

MySQL命令

2012-02-23 10:28:12

MySQL

2013-02-20 16:14:39

Android開(kāi)發(fā)內(nèi)存泄露

2009-11-10 13:08:13

VB.NET編程技巧

2009-11-02 13:14:18

VB.NET函數(shù)

2010-11-23 14:46:20

MySQL內(nèi)存表

2009-11-04 10:35:42

ADO.NET Con

2009-10-26 16:53:00

VB.NET常用代碼

2010-05-12 18:48:31

MySQL數(shù)據(jù)庫(kù)

2009-11-10 11:25:35

VB.NET與Basi

2010-04-19 13:31:29

無(wú)線網(wǎng)絡(luò)故障

2009-10-21 09:19:40

VB.NET文件壓縮 

2010-05-14 17:27:40

MySQL中文亂碼

2019-09-24 08:56:00

內(nèi)存Redis使用

2010-05-07 14:26:55

Oracle臨時(shí)表

2010-10-12 10:38:14

2009-07-21 14:15:00

iBATIS.NET多

2010-11-23 15:12:03

MySQL授權(quán)表
點(diǎn)贊
收藏

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