• <fieldset id="8imwq"><menu id="8imwq"></menu></fieldset>
  • <bdo id="8imwq"><input id="8imwq"></input></bdo>
    最新文章專題視頻專題問答1問答10問答100問答1000問答2000關鍵字專題1關鍵字專題50關鍵字專題500關鍵字專題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關鍵字專題關鍵字專題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
    當前位置: 首頁 - 科技 - 知識百科 - 正文

    mysql的memory發動機介紹

    來源:懂視網 責編:小采 時間:2020-11-09 13:59:38
    文檔

    mysql的memory發動機介紹

    mysql的memory發動機介紹:mysql 的 memory 引擎介紹 Mysql 數據庫 memory 引擎簡介 使用場景:需要高速的動態的查詢數據庫,相比于memcached它的動態性更強。 如何查看自己當前的數據庫的引擎。 mysql show engines ; 結果在附件中. HEAP 簡介 :(heap
    推薦度:
    導讀mysql的memory發動機介紹:mysql 的 memory 引擎介紹 Mysql 數據庫 memory 引擎簡介 使用場景:需要高速的動態的查詢數據庫,相比于memcached它的動態性更強。 如何查看自己當前的數據庫的引擎。 mysql show engines ; 結果在附件中. HEAP 簡介 :(heap

    mysql 的 memory 引擎介紹 Mysql 數據庫 memory 引擎簡介 ? 使用場景:需要高速的動態的查詢數據庫,相比于memcached它的動態性更強。 ? 如何查看自己當前的數據庫的引擎。 mysql show engines ; 結果在附件中. ? ? HEAP 簡介 :(heap 其實就是memory引擎。)

    mysql 的 memory 引擎介紹

    Mysql 數據庫 memory引擎簡介

    ?

    使用場景:需要高速的動態的查詢數據庫,相比于memcached它的動態性更強。

    ?

    如何查看自己當前的數據庫的引擎。

    mysql> show engines;

    結果在附件中.

    ?

    ? HEAP簡介:(heap 其實就是memory引擎。)

    HEAP允許只駐留在內存里的臨時表格。駐留在內存里讓HEAP要比MYISAM快,但是它所管理的數據是不穩定的,而且如果在關機之前沒有進行保存,那么所有的數據都會丟失。在數據行被刪除的時候,HEAP也不會浪費大量的空間。HEAP表格在你需要使用SELECT表達式來選擇和操控數據的時候非常有用。

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

    特性:

    ???????? 1.2 MEMORY引擎的存儲特性

    MEMORY引擎的數據及索引數據都存儲于內存中,為此文件系統只會有一個單獨的表定義文件,例如: MEMMORY引擎的表:t_memory,在數據庫目錄下只有:t_memory.frm文件,正是由于其所有數據都存儲于內存中,除表定義信息有對應的實體文件存儲于磁盤上外,只要mysqld服務不存在,則表中的數據全部丟失。

      對MEMORY引擎表做DELETE刪除數據的操作,并不是真正刪除,而是標記為刪除狀態,只有新記錄INSERT且寫入同一張表才可重用,另外重建、重置、刪除表、mysqld服務重啟,才會釋放掉被刪除數據所占的內存。

      1.3 數據類型的支持

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

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

      3>.支持創建自增序列的字段;

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

      1.4 索引的支持

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

    ?使用:

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

    ?測試:

    二.觸發器的知識點

      2.1 語法

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

      2.1.1創建

      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>.一個數據庫中不能有同名的觸發器程序;

      2>.同一表上,對同一個事件的響應處理不能有二個及以上的觸發器;

      3>.觸發器無法顯示調用執行,也無法像函數或存儲過程一樣顯示地傳遞參數;

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

      5>.觸發器的處理部分不能含有事務的關鍵字,例如:ROLLBACK等;

      6>.創建了觸發器的表,若支持事務,則觸發器也會受事務執行成功還是失敗的影響,且觸發器程序執行成功還是失敗,也會影響事務的執行是成功還是失敗;若不支持事務,則也無法支持事務的回滾操作;

      三.模擬的業務場景

      1.對某表中部分符合規定要求的數據UPDATE業務操作量大,且要求響應時間短;

      2.確保數據的安全性;

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

      4.對MEMORY引擎表中的數據,只有UPDATE業務操作;

      5.通過觸發器的方式,更新InnoDB引擎表中的數據;

      測試過程如下:

      1>.創建用于測試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>.添加幾條測試數據

    INSERT INTO t_innodb(username) value('a'),('asdfasdf'),('q235423573sdf'),('afdhfhswqertqw');

    INSERT INTO t_memory SELECT * from t_innodb;

      3>.創建基于MEMORY引擎的表上的更新觸發器

    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張表中的數據

    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引擎表執行更新模擬操作

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

      6>.更新之后的數據對比

    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服務,然后查看對比2張表中的數據

    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引擎表支持在線業務,另外再使用觸發器或者類似觸發器的其他程序完成數據同步到實體表,那么從MEMORY引擎特點、業務等角度提出以下建議:

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

      2>.刪除MEMORY引擎表中的數據之后,使用語句ALTER TABLE tablename ENGINE=MEMORY釋放掉被刪除數據而占用的內存;

      3>.只使用MEMORY引擎表支持UPDATE操作業務;

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

      5>.不要是用MEMORY引擎表支持數據量過大的業務,比如數據量1G以上;

      6>.要定期清理MEMORY引擎表中不需要的數據,以便騰出內存;

      7>.參數max_heap_table_size的值要設置合理,考慮系統資源及數據量可能有多大;

      8>.MEMORY引擎不支持事務,為此使用觸發器完成數據同步的工作,要考慮響應操作的時間點(BEFOR/AFTER),由于操作可能會很頻繁,實體表建議使用支持事務的引擎,比如:InnoDB引擎;

    ?

    ?

    聲明:本網頁內容旨在傳播知識,若有侵權等問題請及時與本網聯系,我們將在第一時間刪除處理。TEL:177 7030 7066 E-MAIL:11247931@qq.com

    文檔

    mysql的memory發動機介紹

    mysql的memory發動機介紹:mysql 的 memory 引擎介紹 Mysql 數據庫 memory 引擎簡介 使用場景:需要高速的動態的查詢數據庫,相比于memcached它的動態性更強。 如何查看自己當前的數據庫的引擎。 mysql show engines ; 結果在附件中. HEAP 簡介 :(heap
    推薦度:
    標簽: 介紹 簡介 發動機
    • 熱門焦點

    最新推薦

    猜你喜歡

    熱門推薦

    專題
    Top
    主站蜘蛛池模板: 欧美精品v国产精品v日韩精品| 久久精品成人一区二区三区| 国精品午夜福利视频不卡 | 在线观看日韩精品| 青青草原综合久久大伊人精品| 北条麻妃国产九九九精品视频 | 久久亚洲精品人成综合网| 久久精品成人免费观看97| 午夜影视日本亚洲欧洲精品一区| 国产精品午夜一级毛片密呀 | 欧美精品亚洲精品日韩专区| 亚洲日韩中文在线精品第一 | 精品人妻少妇一区二区三区不卡| 久久精品视频免费| 国产精品女同一区二区| 国产高清在线精品一区二区三区| 四虎永久在线精品免费一区二区| 成人精品视频一区二区三区| 国产在线国偷精品免费看| 麻豆国产在线精品国偷产拍| 午夜精品久久久久久久无码| 国产天天综合永久精品日| 97精品国产97久久久久久免费| 精品成人免费自拍视频| 亚洲国产精品一区二区第四页| 91麻豆精品国产自产在线观看一区 | 亚洲午夜精品久久久久久app| 久久久久久久亚洲精品| 欧美精品91欧美日韩操| 男女男精品网站免费观看| 国产三级精品三级在专区| 国产亚洲精品高清在线| 久久精品成人免费观看97| 欧美精品播放| 亚洲А∨精品天堂在线 | 国产在线精品一区二区不卡| 91视频国产精品| 久久国产精品成人免费| 94久久国产乱子伦精品免费| 国产精品成人99久久久久91gav| 成人午夜精品久久久久久久小说|