MySql 內存表使用

MySql 內存表使用

內存表使用哈希散列索引把數據保存在內存中,所以具備極快的速度,適合緩存中小型數據庫,可是使用上受到一些限制,如下是藍草使用的一些感覺。 
一、heap對全部用戶的鏈接是可見的,這使得它很是適合作緩存。 
二、僅適合使用的場合。heap不容許使用xxxTEXT和xxxBLOB數據類型;只容許使用=和<=>操做符來搜索記錄(不容許<、>、<=或>=);不支持auto_increment;只容許對非空數據列進行索引(not null)。 
注:操做符 「<=>」 說明:NULL-safe equal.這個操做符和「=」操做符執行相同的比較操做,不過在兩個操做碼均爲NULL時,其所得值爲1而不爲NULL,而當一個操做碼爲NULL時,其所得值爲0而不爲NULL。 
三、一旦服務器重啓,全部heap表數據丟失,可是heap表結構仍然存在,由於heap表結構是存放在實際數據庫路徑下的,不會自動刪除。重啓以後,heap將被清空,這時候對heap的查詢結果都是空的。 
四、若是heap是複製的某數據表,則複製以後全部主鍵、索引、自增等格式將不復存在,須要從新添加主鍵和索引,若是須要的話。 
五、對於重啓形成的數據丟失,有如下的解決辦法: 
a、在任何查詢以前,執行一次簡單的查詢,判斷heap表是否存在數據,若是不存在,則把數據從新寫入,或者DROP表從新複製某張表。這須要多作一次查詢。不過能夠寫成include文件,在須要用該heap表的頁面隨時調用,比較方便。 
b、對於須要該heap表的頁面,在該頁面第一次且僅在第一次查詢該表時,對數據集結果進行判斷,若是結果爲空,則須要從新寫入數據。這樣能夠節省一次查詢。 
c、更好的辦法是在mysql每次從新啓動時自動寫入數據到heap,可是須要配置服務器,過程比較複雜,通用性受到限制。 
藍草目前採用的是第二種辦法。 
六、一些預期可能用到的sql語句 
//若是表存在,則刪除 
DROP TABLE IF EXISTS `abc`; 
//複製整張表xyz爲heap表abc(包含全部數據) 
CREATE TABLE `abc` type=heap select * from `xyz`; 
//添加主鍵id 
ALTER TABLE `abc` ADD PRIMARY KEY (`id`); 
//添加索引username 
ALTER TABLE `abc` ADD INDEX `abc` (`username`); 
7.建表實例 
CREATE TABLE `DB` ( 
`id` int(11) default NULL, 
`songname` varchar(255) NOT NULL default '', 
`singer` varchar(255) NOT NULL default '', 
KEY `songname` (`songname`,`singer`) 
) TYPE=HEAP建表時TABLE TYPE 選項也有這個表結構就是創建了內存表。若是MYSQL重啓 那內存表的數據 將會消失。但訪問速度會很快!html

幾個關鍵參數mysql

max_heap_table_size

mysql HEAP MEMORY tables 提升行數支持的方法 
別人問到的 記一下 
mysql MEMORY tables 若是目前支持的行數到上限還不夠用 能夠把 my.conf 配置裏面 
max_heap_table_size = 256M 
改大 
設置 MAX_ROWS 
在跑着 能夠 ALTER TABLE tbl_name MAX_ROWS= 
MAX_ROWS 依賴於 max_heap_table_size 設置sql

個人配置文件數據庫

my.cnf

[mysqld] 
datadir=/var/lib/mysql 
socket=/var/lib/mysql/mysql.sock 
port=5004 
tmp_table_size=1000M 
max_heap_table_size=950M 
# Default to using old password format for compatibility with mysql 3.x 
# clients (those using the mysqlclient10 compatibility package). 
old_passwords=1 
default-character-set=utf8 
default-collation=utf8_bin 
[mysql.server] 
user=mysql 
basedir=/var/lib 
[mysqld_safe] 
default-character-set=utf8 
default-collation=utf8_bin 
log-error=/var/log/mysqld.log 
pid-file=/var/run/mysqld/mysqld.pid 
[client] 
#default-character-set=utf8緩存

 

看MySQL參考手冊 發現CREATE TABLE 時有多種數據庫存儲引擎: 
TYPE = {BDB | HEAP | ISAM | InnoDB | MERGE | MRG_MYISAM | MYISAM } 
MySQL數據庫引擎ISAM,myISAM,heap2007-07-20 23:40若是你是個賽車手而且按一下按鈕就可以當即更換引擎而不須要把車開到車庫裏去換,那會是怎麼感受呢?MySQL數據庫爲開發人員所作的就好像是按按鈕換引擎;它讓你選擇數據庫引擎,並給你一條簡單的途徑來切換它。 
MySQL的自帶引擎確定是夠用了,可是在有些狀況下,其餘的引擎可能要比手頭所用更適合完成任務。若是願意的話,你甚至可使用MySQL++ API來建立本身的數據庫引擎,就像打穿氣缸裝上本身的化油器。如今讓咱們來看看你該如何選擇引擎,以及如何在可用引擎之間切換。 
選擇你的引擎 
你能用的數據庫引擎取決於MySQL在安裝的時候是如何被編譯的。要添加一個新的引擎,就必須從新編譯MySQL。僅僅爲了添加一個特性而編譯應用程序的概念對於Windows的開發人員來講可能很奇怪,可是在UNIX世界裏,這已經成爲了標準。在缺省狀況下,MySQL支持三個引擎:ISAM、MyISAM和HEAP。另外兩種類型InnoDB和Berkley(BDB),也經常可使用。 
ISAM 
ISAM是一個定義明確且歷經時間考驗的數據表格管理方法,它在設計之時就考慮到數據庫被查詢的次數要遠大於更新的次數。所以,ISAM執行讀取操做的速度很快,並且不佔用大量的內存和存儲資源。ISAM的兩個主要不足之處在於,它不支持事務處理,也不可以容錯:若是你的硬盤崩潰了,那麼數據文件就沒法恢復了。若是你正在把ISAM用在關鍵任務應用程序裏,那就必須常常備份你全部的實時數據,經過其複製特性,MySQL可以支持這樣的備份應用程序。 
MyISAM 
MyISAM是MySQL的ISAM擴展格式和缺省的數據庫引擎。除了提供ISAM裏所沒有的索引和字段管理的大量功能,MyISAM還使用一種表格鎖定的機制,來優化多個併發的讀寫操做。其代價是你須要常常運行OPTIMIZE TABLE命令,來恢復被更新機制所浪費的空間。MyISAM還有一些有用的擴展,例如用來修復數據庫文件的MyISAMChk工具和用來恢復浪費空間的MyISAMPack工具。 
MyISAM強調了快速讀取操做,這可能就是爲何MySQL受到了Web開發如此青睞的主要緣由:在Web開發中你所進行的大量數據操做都是讀取操做。因此,大多數虛擬主機提供商和Internet平臺提供商(Internet Presence Provider,IPP)只容許使用MyISAM格式。 
HEAP 
HEAP容許只駐留在內存裏的臨時表格。駐留在內存裏讓HEAP要比ISAM和MyISAM都快,可是它所管理的數據是不穩定的,並且若是在關機以前沒有進行保存,那麼全部的數據都會丟失。在數據行被刪除的時候,HEAP也不會浪費大量的空間。HEAP表格在你須要使用SELECT表達式來選擇和操控數據的時候很是有用。要記住,在用完表格以後就刪除表格。讓我再重複一遍:在你用完表格以後,不要忘記刪除表格。 
InnoDB和Berkley DB 
InnoDB和Berkley DB(BDB)數據庫引擎都是造就MySQL靈活性的技術的直接產品,這項技術就是MySQL++ API。在使用MySQL的時候,你所面對的每個挑戰幾乎都源於ISAM和MyISAM數據庫引擎不支持事務處理也不支持外來鍵。儘管要比ISAM和MyISAM引擎慢不少,可是InnoDB和BDB包括了對事務處理和外來鍵的支持,這兩點都是前兩個引擎所沒有的。如前所述,若是你的設計須要這些特性中的一者或者二者,那你就要被迫使用後兩個引擎中的一個了。 
若是感受本身的確技術高超,你還可以使用MySQL++來建立本身的數據庫引擎。這個API爲你提供了操做字段、記錄、表格、數據庫、鏈接、安全賬號的功能,以及創建諸如MySQL這樣DBMS所須要的全部其餘無數功能。深刻講解API已經超出了本文的範圍,可是你須要瞭解MySQL++的存在及其可交換引擎背後的技術,這一點是很重要的。估計這個插件式數據庫引擎的模型甚至可以被用來爲MySQL建立本地的XML提供器(XML provider)。(任何讀到本文的MySQL++開發人員能夠把這一點看成是個要求。) 
按開關 
讓全部的靈活性成爲可能的開關是提供給ANSI SQL的MySQL擴展——TYPE參數。MySQL可以讓你在表格這一層指定數據庫引擎,因此它們有時候也指的是table formats。下面的示例代碼代表瞭如何建立分別使用MyISAM、ISAM和HEAP引擎的表格。要注意,建立每一個表格的代碼是相同的,除了最後的TYPE參數,這一參數用來指定數據引擎。 
CREATE TABLE tblMyISAM ( 
          id INT NOT NULL AUTO_INCREMENT, 
          PRIMARY KEY (id), 
          value_a TINYINT 
) TYPE=MyISAM 
CREATE TABLE tblISAM ( 
          id INT NOT NULL AUTO_INCREMENT, 
          PRIMARY KEY (id), 
          value_a TINYINT 
) TYPE=ISAM 
CREATE TABLE tblHeap ( 
          id INT NOT NULL AUTO_INCREMENT, 
          PRIMARY KEY (id), 
          value_a TINYINT 
) TYPE=Heap 
你也可使用ALTER TABLE命令,把原有的表格從一個引擎移動到另外一個引擎。下面的代碼顯示瞭如何使用ALTER TABLE把MyISAM表格移動到InnoDB的引擎: 
ALTER TABLE tblMyISAM CHANGE TYPE=InnoDB 
MySQL用三步來實現這一目的。首先,這個表格的一個副本被建立。而後,任何輸入數據的改變都被排入隊列,同時這個副本被移動到另外一個引擎。最後,任何排入隊列的數據改變都被送交到新的表格裏,而原來的表格被刪除。 
-------------------------------------------------------------------------------- 
ALTER TABLE捷徑 
若是隻是想把表格從ISAM更新爲MyISAM,你可使用mysql_convert_table_format命令,而不須要編寫ALTER TABLE表達式。 
-------------------------------------------------------------------------------- 
你可使用SHOW TABLE命令(這是MySQL對ANSI標準的另外一個擴展)來肯定哪一個引擎在管理着特定的表格。SHOW TABLE會返回一個帶有多數據列的結果集,你能夠用這個結果集來查詢得到全部類型的信息:數據庫引擎的名稱在Type字段裏。下面的示例代碼說明了SHOW TABLE的用法: 
SHOW TABLE STATUS FROM tblInnoDB 
-------------------------------------------------------------------------------- 
SHOW TABLE的替換方法 
你能夠用SHOW CREATE TABLE [TableName]來取回SHOW TABLE可以取回的信息。 
-------------------------------------------------------------------------------- 
最後,若是你想使用沒有被編譯成MySQL也沒有被激活的引擎,那是沒有用的,MySQL不會提示這一點。而它只會給你提供一個缺省格式(MyISAM)的表格。除了使用缺省的表格格式外,還有辦法讓MySQL給出錯誤提示,可是就如今而言,若是不能確定特定的數據庫引擎是否可用的話,你要使用SHOW TABLE來檢查表格格式。 
更多的選擇意味着更好的性能 
用於特定表格的引擎都須要從新編譯和追蹤,考慮到這種的額外複雜性,爲何你仍是想要使用非缺省的數據庫引擎呢?答案很簡單:要調整數據庫來知足你的要求。 
能夠確定的是,MyISAM的確快,可是若是你的邏輯設計須要事務處理,你就能夠自由使用支持事務處理的引擎。進一步講,因爲MySQL可以容許你在表格這一層應用數據庫引擎,因此你能夠只對須要事務處理的表格來進行性能優化,而把不須要事務處理的表格交給更加輕便的MyISAM引擎。對於MySQL而言,靈活性纔是關鍵。安全

 

http://www.cnblogs.com/yinpengxiang/archive/2009/03/20/1417606.html性能優化

相關文章
相關標籤/搜索