<span id="mktg5"></span>

<i id="mktg5"><meter id="mktg5"></meter></i>

        <label id="mktg5"><meter id="mktg5"></meter></label>
        最新文章專題視頻專題問答1問答10問答100問答1000問答2000關(guān)鍵字專題1關(guān)鍵字專題50關(guān)鍵字專題500關(guān)鍵字專題1500TAG最新視頻文章推薦1 推薦3 推薦5 推薦7 推薦9 推薦11 推薦13 推薦15 推薦17 推薦19 推薦21 推薦23 推薦25 推薦27 推薦29 推薦31 推薦33 推薦35 推薦37視頻文章20視頻文章30視頻文章40視頻文章50視頻文章60 視頻文章70視頻文章80視頻文章90視頻文章100視頻文章120視頻文章140 視頻2關(guān)鍵字專題關(guān)鍵字專題tag2tag3文章專題文章專題2文章索引1文章索引2文章索引3文章索引4文章索引5123456789101112131415文章專題3
        問答文章1 問答文章501 問答文章1001 問答文章1501 問答文章2001 問答文章2501 問答文章3001 問答文章3501 問答文章4001 問答文章4501 問答文章5001 問答文章5501 問答文章6001 問答文章6501 問答文章7001 問答文章7501 問答文章8001 問答文章8501 問答文章9001 問答文章9501
        當(dāng)前位置: 首頁(yè) - 科技 - 知識(shí)百科 - 正文

        mysql的memory發(fā)動(dòng)機(jī)介紹

        來(lái)源:懂視網(wǎng) 責(zé)編:小采 時(shí)間:2020-11-09 13:59:38
        文檔

        mysql的memory發(fā)動(dòng)機(jī)介紹

        mysql的memory發(fā)動(dòng)機(jī)介紹:mysql 的 memory 引擎介紹 Mysql 數(shù)據(jù)庫(kù) memory 引擎簡(jiǎn)介 使用場(chǎng)景:需要高速的動(dòng)態(tài)的查詢數(shù)據(jù)庫(kù),相比于memcached它的動(dòng)態(tài)性更強(qiáng)。 如何查看自己當(dāng)前的數(shù)據(jù)庫(kù)的引擎。 mysql show engines ; 結(jié)果在附件中. HEAP 簡(jiǎn)介 :(heap
        推薦度:
        導(dǎo)讀mysql的memory發(fā)動(dòng)機(jī)介紹:mysql 的 memory 引擎介紹 Mysql 數(shù)據(jù)庫(kù) memory 引擎簡(jiǎn)介 使用場(chǎng)景:需要高速的動(dòng)態(tài)的查詢數(shù)據(jù)庫(kù),相比于memcached它的動(dòng)態(tài)性更強(qiáng)。 如何查看自己當(dāng)前的數(shù)據(jù)庫(kù)的引擎。 mysql show engines ; 結(jié)果在附件中. HEAP 簡(jiǎn)介 :(heap

        mysql 的 memory 引擎介紹 Mysql 數(shù)據(jù)庫(kù) memory 引擎簡(jiǎn)介 ? 使用場(chǎng)景:需要高速的動(dòng)態(tài)的查詢數(shù)據(jù)庫(kù),相比于memcached它的動(dòng)態(tài)性更強(qiáng)。 ? 如何查看自己當(dāng)前的數(shù)據(jù)庫(kù)的引擎。 mysql show engines ; 結(jié)果在附件中. ? ? HEAP 簡(jiǎn)介 :(heap 其實(shí)就是memory引擎。)

        mysql 的 memory 引擎介紹

        Mysql 數(shù)據(jù)庫(kù) memory引擎簡(jiǎn)介

        ?

        使用場(chǎng)景:需要高速的動(dòng)態(tài)的查詢數(shù)據(jù)庫(kù),相比于memcached它的動(dòng)態(tài)性更強(qiáng)。

        ?

        如何查看自己當(dāng)前的數(shù)據(jù)庫(kù)的引擎。

        mysql> show engines;

        結(jié)果在附件中.

        ?

        ? HEAP簡(jiǎn)介:(heap 其實(shí)就是memory引擎。)

        HEAP允許只駐留在內(nèi)存里的臨時(shí)表格。駐留在內(nèi)存里讓HEAP要比MYISAM快,但是它所管理的數(shù)據(jù)是不穩(wěn)定的,而且如果在關(guān)機(jī)之前沒有進(jìn)行保存,那么所有的數(shù)據(jù)都會(huì)丟失。在數(shù)據(jù)行被刪除的時(shí)候,HEAP也不會(huì)浪費(fèi)大量的空間。HEAP表格在你需要使用SELECT表達(dá)式來(lái)選擇和操控?cái)?shù)據(jù)的時(shí)候非常有用。

        ??????????????????

        特性:

        ???????? 1.2 MEMORY引擎的存儲(chǔ)特性

        MEMORY引擎的數(shù)據(jù)及索引數(shù)據(jù)都存儲(chǔ)于內(nèi)存中,為此文件系統(tǒng)只會(huì)有一個(gè)單獨(dú)的表定義文件,例如: MEMMORY引擎的表:t_memory,在數(shù)據(jù)庫(kù)目錄下只有:t_memory.frm文件,正是由于其所有數(shù)據(jù)都存儲(chǔ)于內(nèi)存中,除表定義信息有對(duì)應(yīng)的實(shí)體文件存儲(chǔ)于磁盤上外,只要mysqld服務(wù)不存在,則表中的數(shù)據(jù)全部丟失。

          對(duì)MEMORY引擎表做DELETE刪除數(shù)據(jù)的操作,并不是真正刪除,而是標(biāo)記為刪除狀態(tài),只有新記錄INSERT且寫入同一張表才可重用,另外重建、重置、刪除表、mysqld服務(wù)重啟,才會(huì)釋放掉被刪除數(shù)據(jù)所占的內(nèi)存。

          1.3 數(shù)據(jù)類型的支持

          1>.除BLOB、TEXT及二者的變種外,其他類型都支持;

          2>.采用固定長(zhǎng)度字段類型,即VARCHAR(50) 等同于CHAR(50);

          3>.支持創(chuàng)建自增序列的字段;

          4>.字段允許為NULL,同時(shí)索引也允許包含為NULL類型的字段;

          1.4 索引的支持

          1.5 存儲(chǔ)空間范圍?? MEMORY存儲(chǔ)引擎擁有的存儲(chǔ)空間,取決于設(shè)置全局變量:max_heap_table_size的值為多大。

        ?使用:

        CREATE TABLE t (i INT) ENGINE = MYISAM;
        注釋:老版本的MySQL使用TYPE而不是ENGINE(例如,TYPE = MYISAM)。MySQL 5.1為向下兼容而支持這個(gè)語(yǔ)法,但TYPE現(xiàn)在被輕視,而ENGINE是首先的用法。

        ?測(cè)試:

        二.觸發(fā)器的知識(shí)點(diǎn)

          2.1 語(yǔ)法

          當(dāng)通過(guò)SQL(INSERT、UPDATE、DELETE)語(yǔ)句使表中的數(shù)據(jù)發(fā)生變化,能捕獲到此變化的程序,即是我們常用到的觸發(fā)器,是一種類似于存儲(chǔ)過(guò)程,而具有特殊作用的程序。

          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>.一個(gè)數(shù)據(jù)庫(kù)中不能有同名的觸發(fā)器程序;

          2>.同一表上,對(duì)同一個(gè)事件的響應(yīng)處理不能有二個(gè)及以上的觸發(fā)器;

          3>.觸發(fā)器無(wú)法顯示調(diào)用執(zhí)行,也無(wú)法像函數(shù)或存儲(chǔ)過(guò)程一樣顯示地傳遞參數(shù);

          4>.通過(guò)關(guān)鍵字OLD.column_name獲得的值不能通過(guò)SET命令修改,但是關(guān)鍵字NEW獲得的值能通過(guò)SET NEW.column_name=VALUE方式修改;

          5>.觸發(fā)器的處理部分不能含有事務(wù)的關(guān)鍵字,例如:ROLLBACK等;

          6>.創(chuàng)建了觸發(fā)器的表,若支持事務(wù),則觸發(fā)器也會(huì)受事務(wù)執(zhí)行成功還是失敗的影響,且觸發(fā)器程序執(zhí)行成功還是失敗,也會(huì)影響事務(wù)的執(zhí)行是成功還是失敗;若不支持事務(wù),則也無(wú)法支持事務(wù)的回滾操作;

          三.模擬的業(yè)務(wù)場(chǎng)景

          1.對(duì)某表中部分符合規(guī)定要求的數(shù)據(jù)UPDATE業(yè)務(wù)操作量大,且要求響應(yīng)時(shí)間短;

          2.確保數(shù)據(jù)的安全性;

          3.為滿足上述要求,且不增加額外的開發(fā)成本,需要從非MEMORY引擎表中讀取數(shù)據(jù)到MEMORY引擎表中;

          4.對(duì)MEMORY引擎表中的數(shù)據(jù),只有UPDATE業(yè)務(wù)操作;

          5.通過(guò)觸發(fā)器的方式,更新InnoDB引擎表中的數(shù)據(jù);

          測(cè)試過(guò)程如下:

          1>.創(chuàng)建用于測(cè)試2張表,存儲(chǔ)引擎分別為: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>.添加幾條測(cè)試數(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>.對(duì)比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>.對(duì)MEMORY引擎表執(zhí)行更新模擬操作

          UPDATE t_memory SET username='769067806dfgh' WHERE ID=1;

          6>.更新之后的數(shù)據(jù)對(duì)比

        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>.重新啟動(dòng)mysqld服務(wù),然后查看對(duì)比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ù)同步到實(shí)體表,那么從MEMORY引擎特點(diǎn)、業(yè)務(wù)等角度提出以下建議:

          1>.MEMORY引擎存儲(chǔ)表中,只使用數(shù)值類型、日期類型的字段且為TIMESTAMP類型,不要使用字符串類型;

          2>.刪除MEMORY引擎表中的數(shù)據(jù)之后,使用語(yǔ)句ALTER TABLE tablename ENGINE=MEMORY釋放掉被刪除數(shù)據(jù)而占用的內(nèi)存;

          3>.只使用MEMORY引擎表支持UPDATE操作業(yè)務(wù);

          4>.對(duì)MEMORY引擎表的數(shù)據(jù)操作,最好是根據(jù)主鍵去完成,以便最快速度完成操作,而不影響其他線程的操作;

          5>.不要是用MEMORY引擎表支持?jǐn)?shù)據(jù)量過(guò)大的業(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)操作的時(shí)間點(diǎn)(BEFOR/AFTER),由于操作可能會(huì)很頻繁,實(shí)體表建議使用支持事務(wù)的引擎,比如:InnoDB引擎;

        ?

        ?

        聲明:本網(wǎng)頁(yè)內(nèi)容旨在傳播知識(shí),若有侵權(quán)等問題請(qǐng)及時(shí)與本網(wǎng)聯(lián)系,我們將在第一時(shí)間刪除處理。TEL:177 7030 7066 E-MAIL:11247931@qq.com

        文檔

        mysql的memory發(fā)動(dòng)機(jī)介紹

        mysql的memory發(fā)動(dòng)機(jī)介紹:mysql 的 memory 引擎介紹 Mysql 數(shù)據(jù)庫(kù) memory 引擎簡(jiǎn)介 使用場(chǎng)景:需要高速的動(dòng)態(tài)的查詢數(shù)據(jù)庫(kù),相比于memcached它的動(dòng)態(tài)性更強(qiáng)。 如何查看自己當(dāng)前的數(shù)據(jù)庫(kù)的引擎。 mysql show engines ; 結(jié)果在附件中. HEAP 簡(jiǎn)介 :(heap
        推薦度:
        • 熱門焦點(diǎn)

        最新推薦

        猜你喜歡

        熱門推薦

        專題
        Top
        主站蜘蛛池模板: 亚洲色精品三区二区一区| 亚洲人成网7777777国产| 亚洲日韩中文字幕| 一级毛片不卡片免费观看| 中文字幕久久亚洲一区 | 亚洲国产精品无码成人片久久| 四虎一区二区成人免费影院网址| 免费国产高清视频| 色噜噜狠狠色综合免费视频 | www在线观看免费视频| 精品亚洲视频在线观看| 精品一区二区三区免费观看| 亚洲成a人片在线观看老师| 日韩精品无码永久免费网站| 久久精品国产亚洲Aⅴ香蕉| 东方aⅴ免费观看久久av| 婷婷亚洲久悠悠色悠在线播放 | 亚洲国产美女精品久久久 | 亚洲情综合五月天| 国产精品99精品久久免费| 亚洲精品线在线观看| 日本免费网站视频www区| 亚洲中文字幕无码爆乳app| 国产精品免费_区二区三区观看| 国产精品亚洲天堂| 亚洲欧洲无码AV电影在线观看| 97青青草原国产免费观看| 2019亚洲午夜无码天堂| 免费观看的av毛片的网站| 一区二区在线视频免费观看| 亚洲乱亚洲乱淫久久| 免费人成视频在线| 一二三区免费视频| 亚洲国产综合在线| 亚洲国产香蕉人人爽成AV片久久 | 亚洲成AV人片在线观看无码| 香蕉97超级碰碰碰免费公| 免费看一级高潮毛片| 亚洲成a人片在线观看无码| 手机在线免费视频| 免费萌白酱国产一区二区三区|