濮阳杆衣贸易有限公司

主頁 > 知識庫 > MySQL使用MRG_MyISAM(MERGE)實(shí)現(xiàn)分表后查詢的示例

MySQL使用MRG_MyISAM(MERGE)實(shí)現(xiàn)分表后查詢的示例

熱門標(biāo)簽:北京人工外呼系統(tǒng)價錢 沃克斯電梯外呼線路圖 天智外呼系統(tǒng) 房產(chǎn)智能外呼系統(tǒng)品牌 400電話鄭州申請 云南語音外呼系統(tǒng)平臺 地圖標(biāo)注被騙三百怎么辦 福州呼叫中心外呼系統(tǒng)哪家好 常州電銷外呼系統(tǒng)一般多少錢

數(shù)據(jù)庫大數(shù)據(jù)量優(yōu)化是一門很大的學(xué)問,也是做為一名開發(fā)者需要掌握的專業(yè)技能。

MySQL分表方式分為垂直分表和水平分表,這兩種分表形式都比較簡單,簡單理解垂直分表指的是:表的記錄并不多,但是字段卻很長,表占用空間很大,檢索表的時候需要執(zhí)行大量的IO,嚴(yán)重降低了性能。這時需要把大的字段拆分到另一個表,并且該表與原表是一對一的關(guān)系。而水平分表則是在同一個數(shù)據(jù)庫內(nèi),把同一個表的數(shù)據(jù)按一定規(guī)則拆到多個表中,目的是優(yōu)化單一表數(shù)據(jù)量過大而產(chǎn)生的性能問題,避免IO爭搶并減少鎖表的幾率。

實(shí)現(xiàn)分表很簡單,復(fù)雜的是分表之后如何查詢數(shù)據(jù)?今天的實(shí)現(xiàn)方式是使用Mysql表引擎MRG_MyISAM(MERGE)
MERGE存儲引擎,也被認(rèn)識為MRG_MyISAM引擎,是一個相同的可以被當(dāng)作一個來用的MyISAM表的集合?!跋嗤币馕吨斜硗瑯拥牧泻退饕畔?。你不能合并列被以不同順序列于其中的表,沒有恰好同樣列的表,或有不同順序索引的表。而且,任何或者所有的表可以用myisampack來壓縮。表選項(xiàng)的差異,比如AVG_ROW_LENGTH, MAX_ROWS或PACK_KEYS都不重要。

當(dāng)你創(chuàng)建一個MERGE表之時,MySQL在磁盤上創(chuàng)建兩個文件。文件名以表的名字開始,并且有一個擴(kuò)展名來指明文件類型。一個.frm文件存儲表定義,一個.MRG文件包含被當(dāng)作一個來用的表的名字。這些表作為MERGE表自身,不必要在同一個數(shù)據(jù)庫中。

你可以對表的集合用SELECT, DELETE, UPDATE和INSERT。你必須對你映射到一個MERGE表的這些表有SELECT, UPDATE和DELETE 的權(quán)限。

如果你DROP MERGE表,你僅在移除MERGE規(guī)格。底層表沒有受影響。

當(dāng)你創(chuàng)建一個MERGE表之時,你必須指定一個UNION=(list-of-tables)子句,它說明你要把哪些表當(dāng)作一個來用。如果你想要對MERGE表的插入發(fā)生在UNION列表中的第一個或最后一個表上,你可以選擇地指定一個INSERT_METHOD選項(xiàng)。使用FIRST或LAST值使得插入被相應(yīng)地做在第一或最后一個表上。如果你沒有指定INSERT_METHOD選項(xiàng),或你用一個NO值指定該選項(xiàng)。往MERGE表插入記錄的試圖導(dǎo)致錯誤。

舉個例子:
創(chuàng)建兩個子分表:

CREATE TABLE `yzm_table1` (
  `id` int(10) unsigned NOT NULL,
  `title` varchar(100) NOT NULL DEFAULT '',
  `content` varchar(255) NOT NULL DEFAULT '',
  PRIMARY KEY (`id`)
) ENGINE=MyISAM DEFAULT CHARSET=utf8;

CREATE TABLE `yzm_table2` (
  `id` int(10) unsigned NOT NULL,
  `title` varchar(100) NOT NULL DEFAULT '',
  `content` varchar(255) NOT NULL DEFAULT '',
  PRIMARY KEY (`id`)
) ENGINE=MyISAM DEFAULT CHARSET=utf8;

表創(chuàng)建完畢了,需要注意的是這里的id不能設(shè)為自增,而且所有的表結(jié)構(gòu)必須一致,包括結(jié)構(gòu),類型,長度,字段的順序都必須一致那么對于這個id如何取得呢?后面我會詳細(xì)說明?,F(xiàn)在,我們需要一個合并表,用于查詢,創(chuàng)建合并表的代碼如下:

CREATE TABLE `yzm_table` (
  `id` int(10) unsigned NOT NULL AUTO_INCREMENT,
  `title` varchar(100) NOT NULL DEFAULT '',
  `content` varchar(255) NOT NULL DEFAULT '',
  PRIMARY KEY (`id`)
) ENGINE=MRG_MyISAM DEFAULT CHARSET=utf8 INSERT_METHOD=NO INSERT_METHOD=LAST UNION=(`yzm_table1`,`yzm_table2`);

合并表也必須和前面的表有相同的結(jié)構(gòu),類型,長度,包括字段的順序都必須一致這里的 INSERT_METHOD=NO 表示不允許對本表進(jìn)行insert操作。好了,當(dāng)需要查詢的時候,我們可以只對yzm_table這個表進(jìn)行操作就可以了,也就是說這個表僅僅只能進(jìn)行select操作。

插入一些數(shù)據(jù)測試:

INSERT INTO `yzm_table1` VALUES ('1', 'table1-1', 'content1-1');
INSERT INTO `yzm_table1` VALUES ('2', 'table1-2', 'content1-2');
INSERT INTO `yzm_table2` VALUES ('3', 'table2-1', 'content2-1');
INSERT INTO `yzm_table2` VALUES ('4', 'table2-2', 'content2-2');
INSERT INTO `yzm_table2` VALUES ('5', 'table2-3', 'content2-3');

然后查詢合并表(主表)

SELECT * FROM `yzm_table` LIMIT 10;

果然可以查詢到所有關(guān)聯(lián)子表的所有數(shù)據(jù),這樣就可以對所有的數(shù)據(jù)進(jìn)行分頁、統(tǒng)計等查詢了。

以上就是MySQL使用MRG_MyISAM(MERGE)實(shí)現(xiàn)分表后查詢的示例的詳細(xì)內(nèi)容,更多關(guān)于MySQL 分表后查詢的資料請關(guān)注腳本之家其它相關(guān)文章!

您可能感興趣的文章:
  • MySql分表、分庫、分片和分區(qū)知識點(diǎn)介紹
  • MySQL數(shù)據(jù)庫優(yōu)化之分表分庫操作實(shí)例詳解
  • MySQL分表和分區(qū)的具體實(shí)現(xiàn)方法
  • MySQL分庫分表總結(jié)講解
  • Mysql的水平分表與垂直分表的講解
  • mysql分表分庫的應(yīng)用場景和設(shè)計方式
  • mysql數(shù)據(jù)庫分表分庫的策略
  • MySQL 5.7雙主同步部分表的實(shí)現(xiàn)過程詳解
  • MyBatis實(shí)現(xiàn)Mysql數(shù)據(jù)庫分庫分表操作和總結(jié)(推薦)
  • 什么是分表和分區(qū) MySql數(shù)據(jù)庫分區(qū)和分表方法
  • MYSQL數(shù)據(jù)庫數(shù)據(jù)拆分之分庫分表總結(jié)
  • MySQL分表自增ID問題的解決方法

標(biāo)簽:徐州 珠海 黔東 鹽城 拉薩 沈陽 沈陽 移動

巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《MySQL使用MRG_MyISAM(MERGE)實(shí)現(xiàn)分表后查詢的示例》,本文關(guān)鍵詞  MySQL,使用,MRG,MyISAM,MERGE,;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問題,煩請?zhí)峁┫嚓P(guān)信息告之我們,我們將及時溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無關(guān)。
  • 相關(guān)文章
  • 下面列出與本文章《MySQL使用MRG_MyISAM(MERGE)實(shí)現(xiàn)分表后查詢的示例》相關(guān)的同類信息!
  • 本頁收集關(guān)于MySQL使用MRG_MyISAM(MERGE)實(shí)現(xiàn)分表后查詢的示例的相關(guān)信息資訊供網(wǎng)民參考!
  • 推薦文章
    博乐市| 武强县| 大港区| 佳木斯市| 温泉县| 和田市| 宁南县| 西峡县| 五常市| 琼中| 河源市| 蚌埠市| 观塘区| 永仁县| 临城县| 怀宁县| 漠河县| 上饶市| 大荔县| 元朗区| 石嘴山市| 忻州市| 河北区| 大连市| 阜平县| 正宁县| 龙陵县| 高雄市| 黄梅县| 郴州市| 林甸县| 仁布县| 当阳市| 和林格尔县| 乐安县| 游戏| 广饶县| 华坪县| 澜沧| 涟水县| 巢湖市|