溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點(diǎn)擊 登錄注冊 即表示同意《億速云用戶服務(wù)條款》

MySQL Merge引擎實(shí)現(xiàn)分表

發(fā)布時(shí)間:2020-10-14 06:16:11 來源:網(wǎng)絡(luò) 閱讀:2231 作者:無心低語 欄目:MySQL數(shù)據(jù)庫

Merge引擎是一組MyISAM表的組合,組合的分表結(jié)構(gòu)必須完全相同,Merge表本身沒有數(shù)據(jù),對Merge表的操作實(shí)際上都是對子表的操作,只是對APP來說是透明的,在插入的時(shí)候默認(rèn)是插入到最后一張表上,也可以指定插入到第一張表上,Merger表實(shí)際上只是多個(gè)子表的一個(gè)外殼,對它進(jìn)行刪除,不影響實(shí)際存儲的數(shù)據(jù)。

創(chuàng)建子表user1

CREATE TABLE `user1` (
  `id` int(11) NOT NULL AUTO_INCREMENT,
  `name` varchar(100) CHARACTER SET latin1 DEFAULT NULL,
  PRIMARY KEY (`id`)
) ENGINE=MyISAM AUTO_INCREMENT=2 DEFAULT CHARSET=utf8;

創(chuàng)建子表user2

CREATE TABLE `user2` (
  `id` int(11) NOT NULL AUTO_INCREMENT,
  `name` varchar(100) CHARACTER SET latin1 DEFAULT NULL,
  PRIMARY KEY (`id`)
) ENGINE=MyISAM AUTO_INCREMENT=2 DEFAULT CHARSET=utf8;

創(chuàng)建Merge表alluser

CREATE TABLE `alluser` (
  `id` int(11) NOT NULL,
  `name` varchar(100) DEFAULT NULL,
  PRIMARY KEY (`id`)
) ENGINE=MRG_MyISAM DEFAULT CHARSET=latin1 INSERT_METHOD=LAST UNION=(`user1`,`user2`);

現(xiàn)在對alluser進(jìn)行插入數(shù)據(jù)

MySQL Merge引擎實(shí)現(xiàn)分表MySQL Merge引擎實(shí)現(xiàn)分表

然后查看user2表的數(shù)據(jù)發(fā)現(xiàn)已經(jīng)插入進(jìn)去

MySQL Merge引擎實(shí)現(xiàn)分表

下一步對子表分表進(jìn)行插入操作,然后查看alluser表

MySQL Merge引擎實(shí)現(xiàn)分表

MySQL Merge引擎實(shí)現(xiàn)分表

MySQL Merge引擎實(shí)現(xiàn)分表

發(fā)現(xiàn)對子表的插入操作最后都會映射到alluser表中,從一定意義上實(shí)現(xiàn)了分表,但是也有局限性,就是數(shù)據(jù)分布不均勻,因?yàn)椴迦氲臅r(shí)候不能自定義規(guī)則,只能插入創(chuàng)建時(shí)指定的子表,還有就沒有約束條件的檢查,例如在三張表中都設(shè)定id為主鍵,我們在user2中插入一條user1中已經(jīng)存在的數(shù)據(jù),但是alluser表并不報(bào)錯(cuò)且成功插入

MySQL Merge引擎實(shí)現(xiàn)分表

MySQL Merge引擎實(shí)現(xiàn)分表

由于這些原因,Merge引擎實(shí)現(xiàn)的分表在實(shí)際應(yīng)用中并不多


向AI問一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI