MySQL 是一種常用的關(guān)系型數(shù)據(jù)庫(kù),在日常開發(fā)中也經(jīng)常涉及到點(diǎn)贊功能,對(duì)于點(diǎn)贊功能的實(shí)現(xiàn),常常需要用到點(diǎn)贊表。下面我們將探討 MySQL 點(diǎn)贊表分表策略。
點(diǎn)贊表是一個(gè)用于記錄用戶點(diǎn)贊信息的表,至少包含用戶 ID 和點(diǎn)贊對(duì)象 ID 兩個(gè)字段。在實(shí)際使用中,點(diǎn)贊表并不是一個(gè)小型的表,因?yàn)橛脩艉忘c(diǎn)贊對(duì)象的數(shù)量都是大量的。因此,如果不進(jìn)行分表處理,可能會(huì)出現(xiàn)查詢效率低下、寫入鎖定等問題。下面是點(diǎn)贊表的示例結(jié)構(gòu):
CREATE TABLE `like` (
`id` int(11) NOT NULL AUTO_INCREMENT COMMENT '主鍵',
`user_id` int(11) NOT NULL COMMENT '用戶 ID',
`object_id` int(11) NOT NULL COMMENT '點(diǎn)贊對(duì)象 ID',
`create_time` datetime NOT NULL COMMENT '創(chuàng)建時(shí)間',
PRIMARY KEY (`id`),
KEY `user_object` (`user_id`,`object_id`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8 COMMENT='點(diǎn)贊表';
對(duì)于點(diǎn)贊表數(shù)據(jù)的分表,常用的策略是根據(jù) user_id 進(jìn)行 ID 取模的方式進(jìn)行分表。例如,如果想要將點(diǎn)贊表分成 10 個(gè)子表,可以使用下面的 SQL 語(yǔ)句生成:
CREATE TABLE `like_0` (
`id` int(11) NOT NULL AUTO_INCREMENT COMMENT '主鍵',
`user_id` int(11) NOT NULL COMMENT '用戶 ID',
`object_id` int(11) NOT NULL COMMENT '點(diǎn)贊對(duì)象 ID',
`create_time` datetime NOT NULL COMMENT '創(chuàng)建時(shí)間',
PRIMARY KEY (`id`),
KEY `user_object` (`user_id`,`object_id`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8 COMMENT='點(diǎn)贊表';
CREATE TABLE `like_1` (
`id` int(11) NOT NULL AUTO_INCREMENT COMMENT '主鍵',
`user_id` int(11) NOT NULL COMMENT '用戶 ID',
`object_id` int(11) NOT NULL COMMENT '點(diǎn)贊對(duì)象 ID',
`create_time` datetime NOT NULL COMMENT '創(chuàng)建時(shí)間',
PRIMARY KEY (`id`),
KEY `user_object` (`user_id`,`object_id`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8 COMMENT='點(diǎn)贊表';
...
CREATE TABLE `like_9` (
`id` int(11) NOT NULL AUTO_INCREMENT COMMENT '主鍵',
`user_id` int(11) NOT NULL COMMENT '用戶 ID',
`object_id` int(11) NOT NULL COMMENT '點(diǎn)贊對(duì)象 ID',
`create_time` datetime NOT NULL COMMENT '創(chuàng)建時(shí)間',
PRIMARY KEY (`id`),
KEY `user_object` (`user_id`,`object_id`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8 COMMENT='點(diǎn)贊表';
這樣之后,我們?cè)谶M(jìn)行點(diǎn)贊操作時(shí),可以根據(jù) user_id 的值計(jì)算出對(duì)應(yīng)的子表,再進(jìn)行點(diǎn)贊數(shù)據(jù)的寫入。對(duì)于點(diǎn)贊查詢,也可以根據(jù) user_id 算出對(duì)應(yīng)的表進(jìn)行查詢,這樣可以減少表內(nèi)數(shù)據(jù)量,從而提高查詢效率。
綜上所述,MySQL 點(diǎn)贊表分表策略是在大數(shù)據(jù)量情況下,為了提升查詢效率,可以將點(diǎn)贊表按照 user_id 進(jìn)行 ID 取模進(jìn)行分表,達(dá)到降低表內(nèi)數(shù)據(jù)量的效果。