mysql 的 memory 引擎介紹 Mysql 數(shù)據(jù)庫 memory 引擎簡介 ? 使用場景:需要高速的動態(tài)的查詢數(shù)據(jù)庫,相比于memcached它的動態(tài)性更強。 ? 如何查看自己當(dāng)前的數(shù)據(jù)庫的引擎。 mysql show engines ; 結(jié)果在附件中. ? ? HEAP 簡介 :(heap 其實就是memory引擎。)
mysql 的 memory 引擎介紹Mysql 數(shù)據(jù)庫 memory引擎簡介
?
使用場景:需要高速的動態(tài)的查詢數(shù)據(jù)庫,相比于memcached它的動態(tài)性更強。
?
如何查看自己當(dāng)前的數(shù)據(jù)庫的引擎。
mysql> show engines;
結(jié)果在附件中.
?
? HEAP簡介:(heap 其實就是memory引擎。)
HEAP允許只駐留在內(nèi)存里的臨時表格。駐留在內(nèi)存里讓HEAP要比MYISAM快,但是它所管理的數(shù)據(jù)是不穩(wěn)定的,而且如果在關(guān)機之前沒有進行保存,那么所有的數(shù)據(jù)都會丟失。在數(shù)據(jù)行被刪除的時候,HEAP也不會浪費大量的空間。HEAP表格在你需要使用SELECT表達(dá)式來選擇和操控數(shù)據(jù)的時候非常有用。
??????????????????
特性:
???????? 1.2 MEMORY引擎的存儲特性
MEMORY引擎的數(shù)據(jù)及索引數(shù)據(jù)都存儲于內(nèi)存中,為此文件系統(tǒng)只會有一個單獨的表定義文件,例如: MEMMORY引擎的表:t_memory,在數(shù)據(jù)庫目錄下只有:t_memory.frm文件,正是由于其所有數(shù)據(jù)都存儲于內(nèi)存中,除表定義信息有對應(yīng)的實體文件存儲于磁盤上外,只要mysqld服務(wù)不存在,則表中的數(shù)據(jù)全部丟失。
對MEMORY引擎表做DELETE刪除數(shù)據(jù)的操作,并不是真正刪除,而是標(biāo)記為刪除狀態(tài),只有新記錄INSERT且寫入同一張表才可重用,另外重建、重置、刪除表、mysqld服務(wù)重啟,才會釋放掉被刪除數(shù)據(jù)所占的內(nèi)存。
1.3 數(shù)據(jù)類型的支持
1>.除BLOB、TEXT及二者的變種外,其他類型都支持;
2>.采用固定長度字段類型,即VARCHAR(50) 等同于CHAR(50);
3>.支持創(chuàng)建自增序列的字段;
4>.字段允許為NULL,同時索引也允許包含為NULL類型的字段;
1.4 索引的支持
1.5 存儲空間范圍?? MEMORY存儲引擎擁有的存儲空間,取決于設(shè)置全局變量:max_heap_table_size的值為多大。
?使用:
CREATE TABLE t (i INT) ENGINE = MYISAM;
注釋:老版本的MySQL使用TYPE而不是ENGINE(例如,TYPE = MYISAM)。MySQL 5.1為向下兼容而支持這個語法,但TYPE現(xiàn)在被輕視,而ENGINE是首先的用法。
?測試:
二.觸發(fā)器的知識點
2.1 語法
當(dāng)通過SQL(INSERT、UPDATE、DELETE)語句使表中的數(shù)據(jù)發(fā)生變化,能捕獲到此變化的程序,即是我們常用到的觸發(fā)器,是一種類似于存儲過程,而具有特殊作用的程序。
2.1.1創(chuàng)建
CREATE [DEFINER = { user | CURRENT_USER }]
TRIGGER trigger_name trigger_time trigger_event
ON tbl_name FOR EACH ROW trigger_stmt
2.1.2 刪除
DROP TRIGGER [IF EXISTS] [schema_name.]trigger_name
2.2 限制
1>.一個數(shù)據(jù)庫中不能有同名的觸發(fā)器程序;
2>.同一表上,對同一個事件的響應(yīng)處理不能有二個及以上的觸發(fā)器;
3>.觸發(fā)器無法顯示調(diào)用執(zhí)行,也無法像函數(shù)或存儲過程一樣顯示地傳遞參數(shù);
4>.通過關(guān)鍵字OLD.column_name獲得的值不能通過SET命令修改,但是關(guān)鍵字NEW獲得的值能通過SET NEW.column_name=VALUE方式修改;
5>.觸發(fā)器的處理部分不能含有事務(wù)的關(guān)鍵字,例如:ROLLBACK等;
6>.創(chuàng)建了觸發(fā)器的表,若支持事務(wù),則觸發(fā)器也會受事務(wù)執(zhí)行成功還是失敗的影響,且觸發(fā)器程序執(zhí)行成功還是失敗,也會影響事務(wù)的執(zhí)行是成功還是失敗;若不支持事務(wù),則也無法支持事務(wù)的回滾操作;
三.模擬的業(yè)務(wù)場景
1.對某表中部分符合規(guī)定要求的數(shù)據(jù)UPDATE業(yè)務(wù)操作量大,且要求響應(yīng)時間短;
2.確保數(shù)據(jù)的安全性;
3.為滿足上述要求,且不增加額外的開發(fā)成本,需要從非MEMORY引擎表中讀取數(shù)據(jù)到MEMORY引擎表中;
4.對MEMORY引擎表中的數(shù)據(jù),只有UPDATE業(yè)務(wù)操作;
5.通過觸發(fā)器的方式,更新InnoDB引擎表中的數(shù)據(jù);
測試過程如下:
1>.創(chuàng)建用于測試2張表,存儲引擎分別為:MEMORY、InnoDB
CREATE TABLE `t_memory` (
? `id` INT UNSIGNED NOT NULL AUTO_INCREMENT,
? `username` VARCHAR(40) NOT NULL,
? PRIMARY KEY(`id`),
? UNIQUE KEY `idx_username` (`username`)
) ENGINE=MEMORY DEFAULT CHARSET=utf8? COLLATE 'utf8_general_ci';
?
?CREATE TABLE `t_innodb` (
? `id` INT UNSIGNED NOT NULL AUTO_INCREMENT,
? `username` VARCHAR(40) NOT NULL,
? PRIMARY KEY? (`id`),
? UNIQUE KEY `idx_username` (`username`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8 COLLATE 'utf8_general_ci';
2>.添加幾條測試數(shù)據(jù)
INSERT INTO t_innodb(username) value('a'),('asdfasdf'),('q235423573sdf'),('afdhfhswqertqw');
INSERT INTO t_memory SELECT * from t_innodb;
3>.創(chuàng)建基于MEMORY引擎的表上的更新觸發(fā)器
DELIMITER &&
CREATE TRIGGER tri_memory_update AFTER UPDATE ON t_memory FOR EACH ROW
BEGIN?
??? UPDATE t_innodb SET username=NEW.username WHERE username=OLD.username;
END &&
DELIMITER ;
4>.對比2張表中的數(shù)據(jù)
root@localhost : test 03:58:25> select * from t_memory;
+----+----------------+
| id | username?????? |
+----+----------------+
|? 1 | a????????????? |?
|? 2 | asdfasdf?????? |?
|? 3 | q235423573sdf? |?
|? 4 | afdhfhswqertqw |?
+----+----------------+
4 rows in set (0.00 sec)
?
root@localhost : test 03:58:32> select * from t_innodb;
+----+----------------+
| id | username?????? |
+----+----------------+
|? 1 | a????????????? |?
|? 4 | afdhfhswqertqw |?
|? 2 | asdfasdf?????? |?
|? 3 | q235423573sdf? |?
+----+----------------+
4 rows in set (0.00 sec)
5>.對MEMORY引擎表執(zhí)行更新模擬操作
UPDATE t_memory SET username='769067806dfgh' WHERE ID=1;
6>.更新之后的數(shù)據(jù)對比
root@localhost : test 03:58:25> select * from t_memory;
+----+----------------+
| id | username?????? |
+----+----------------+
|? 1 | 769067806dfgh? |?
|? 2 | asdfasdf?????? |?
|? 3 | q235423573sdf? |?
|? 4 | afdhfhswqertqw |?
+----+----------------+
4 rows in set (0.00 sec)
root@localhost : test 03:58:32> select * from t_innodb;
+----+----------------+
| id | username?????? |
+----+----------------+
|? 1 | 769067806dfgh? |?
|? 4 | afdhfhswqertqw |?
|? 2 | asdfasdf?????? |?
|? 3 | q235423573sdf? |?
+----+----------------+
4 rows in set (0.00 sec)
?
7>.重新啟動mysqld服務(wù),然后查看對比2張表中的數(shù)據(jù)
root@localhost : test 04:10:05> select * from t_innodb;
+----+----------------+
| id | username?????? |
+----+----------------+
|? 1 | 769067806dfgh? |?
|? 4 | afdhfhswqertqw |?
|? 2 | asdfasdf?????? |?
|? 3 | q235423573sdf? |?
+----+----------------+
4 rows in set (0.02 sec)
root@localhost : test 04:10:12> select * from t_memory;
Empty set (0.00 sec)
若是采用MEMORY引擎表支持在線業(yè)務(wù),另外再使用觸發(fā)器或者類似觸發(fā)器的其他程序完成數(shù)據(jù)同步到實體表,那么從MEMORY引擎特點、業(yè)務(wù)等角度提出以下建議:
1>.MEMORY引擎存儲表中,只使用數(shù)值類型、日期類型的字段且為TIMESTAMP類型,不要使用字符串類型;
2>.刪除MEMORY引擎表中的數(shù)據(jù)之后,使用語句ALTER TABLE tablename ENGINE=MEMORY釋放掉被刪除數(shù)據(jù)而占用的內(nèi)存;
3>.只使用MEMORY引擎表支持UPDATE操作業(yè)務(wù);
4>.對MEMORY引擎表的數(shù)據(jù)操作,最好是根據(jù)主鍵去完成,以便最快速度完成操作,而不影響其他線程的操作;
5>.不要是用MEMORY引擎表支持?jǐn)?shù)據(jù)量過大的業(yè)務(wù),比如數(shù)據(jù)量1G以上;
6>.要定期清理MEMORY引擎表中不需要的數(shù)據(jù),以便騰出內(nèi)存;
7>.參數(shù)max_heap_table_size的值要設(shè)置合理,考慮系統(tǒng)資源及數(shù)據(jù)量可能有多大;
8>.MEMORY引擎不支持事務(wù),為此使用觸發(fā)器完成數(shù)據(jù)同步的工作,要考慮響應(yīng)操作的時間點(BEFOR/AFTER),由于操作可能會很頻繁,實體表建議使用支持事務(wù)的引擎,比如:InnoDB引擎;
?
?
聲明:本網(wǎng)頁內(nèi)容旨在傳播知識,若有侵權(quán)等問題請及時與本網(wǎng)聯(lián)系,我們將在第一時間刪除處理。TEL:177 7030 7066 E-MAIL:11247931@qq.com