MySQL按年月分區建表是一種優化數據庫性能的方法,它將表按照年月分散到多個表中,可以減少單表的數據量,提高數據的檢索速度。下面是具體實現的步驟:
-- 創建主表 CREATE TABLE `order` ( `id` int(11) NOT NULL AUTO_INCREMENT COMMENT '訂單ID', `order_no` varchar(20) NOT NULL COMMENT '訂單編號', `order_time` datetime NOT NULL COMMENT '下單時間', `amount` decimal(10,2) NOT NULL COMMENT '訂單金額', PRIMARY KEY (`id`), KEY `idx_order_time` (`order_time`) ) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4 COMMENT='訂單表'; -- 創建分區表(以年月為分區條件) CREATE TABLE `order_201901` ( `id` int(11) NOT NULL AUTO_INCREMENT COMMENT '訂單ID', `order_no` varchar(20) NOT NULL COMMENT '訂單編號', `order_time` datetime NOT NULL COMMENT '下單時間', `amount` decimal(10,2) NOT NULL COMMENT '訂單金額', PRIMARY KEY (`id`), KEY `idx_order_time` (`order_time`) ) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4 COMMENT='2019年1月訂單表' PARTITION BY RANGE( YEAR(order_time)*100 + MONTH(order_time) ) ( PARTITION p201901 VALUES LESS THAN (201902), PARTITION p201902 VALUES LESS THAN (201903), PARTITION p201903 VALUES LESS THAN (201904), PARTITION p201904 VALUES LESS THAN (201905), PARTITION p201905 VALUES LESS THAN (201906), PARTITION p201906 VALUES LESS THAN (201907), PARTITION p201907 VALUES LESS THAN (201908), PARTITION p201908 VALUES LESS THAN (201909), PARTITION p201909 VALUES LESS THAN (201910), PARTITION p201910 VALUES LESS THAN (201911), PARTITION p201911 VALUES LESS THAN (201912), PARTITION p201912 VALUES LESS THAN (202001) );
在創建主表時,需要根據實際業務需求設計表結構和索引。在創建分區表時,需要指定分區條件和每個分區的范圍,以及每個分區對應的表名。例如上面的代碼中,以年月為分區條件,可以在每個月的1日添加新表,每個分區的范圍為上個月的1日到這個月的1日,例如p201901的范圍為2019年1月1日到2019年2月1日。
下一篇css按鈕出現小手