時間:2024-03-07 21:27作者:下載吧人氣:12
導讀
有個表做了分區,每天一個分區。
該表上有個查詢,經常只查詢表中某一天數據,但每次都幾乎要掃描整個分區的所有數據,有什么辦法進行優化嗎?
待優化場景
有一個大表,每天產生的數據量約100萬,所以就采用表分區方案,每天一個分區。
下面是該表的DDL:
CREATE TABLE `t1` (
`id` bigint(20) NOT NULL AUTO_INCREMENT,
`date` date NOT NULL,
`kid` int(11) DEFAULT ‘0’,
`uid` int(11) NOT NULL,
`iid` int(11) DEFAULT ‘0’,
`icnt` int(8) DEFAULT ‘0’,
`tst` timestamp NOT NULL DEFAULT CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP,
`countp` smallint(11) DEFAULT ‘1’,
`isr` int(2) NOT NULL DEFAULT ‘0’,
`clv` int(5) NOT NULL DEFAULT ‘1’,
PRIMARY KEY (`id`,`date`),
UNIQUE KEY `date` (`date`,`uid`,`iid`),
KEY `date_2` (`date`,`kid`)
) ENGINE=InnoDB AUTO_INCREMENT=3180686682 DEFAULT CHARSET=utf8mb4
/*!50500 PARTITION BY RANGE COLUMNS(`date`)
(PARTITION p20161201 VALUES LESS THAN (‘2016-12-02’) ENGINE = InnoDB,
PARTITION p20161202 VALUES LESS THAN (‘2016-12-03’) ENGINE = InnoDB,
PARTITION p20161203 VALUES LESS THAN (‘2016-12-04’) ENGINE = InnoDB,
網友評論