本篇內容主要講解“MYSQL表分區測試命令”,感興趣的朋友不妨來看看。本文介紹的方法操作簡單快捷,實用性強。下面就讓小編來帶大家學習“MYSQL表分區測試命令”吧!
參考:https://blog.csdn.net/fengnp/article/details/81239286
-- 1. 創建分區表
CREATE TABLE part_tab(
c1 INT DEFAULT NULL,
c2 VARCHAR(30) DEFAULT NULL,
c3 DATE NOT NULL
) PARTITION BY RANGE(YEAR(c3)) (
PARTITION p0 VALUES LESS THAN (1995),
PARTITION p1 VALUES LESS THAN (1996) ,
PARTITION p2 VALUES LESS THAN (1997) ,
PARTITION p3 VALUES LESS THAN (1998) ,
PARTITION p4 VALUES LESS THAN (1999) ,
PARTITION p5 VALUES LESS THAN (2000) ,
PARTITION p6 VALUES LESS THAN (2001) ,
PARTITION p7 VALUES LESS THAN (2002) ,
PARTITION p8 VALUES LESS THAN (2003) ,
PARTITION p9 VALUES LESS THAN (2004) ,
PARTITION p10 VALUES LESS THAN (2010),
PARTITION p11 VALUES LESS THAN (MAXVALUE)
);
-- 2. 創建不分區表
CREATE TABLE no_part_tab(
c1 INT DEFAULT NULL,
c2 VARCHAR(30) DEFAULT NULL,
c3 DATE NOT NULL
);
-- 3. 查詢
SELECT * FROM part_tab;
SELECT * FROM no_part_tab;
-- 4. 存儲過程插入數據
DROP PROCEDURE IF EXISTS load_part_tab;
DELIMITER //
CREATE PROCEDURE load_part_tab()
BEGIN
DECLARE v INT DEFAULT 0;
WHILE v < 8000000
DO
INSERT INTO part_tab VALUES (v, 'testing partitions', ADDDATE('1995-01-01', (RAND(v)*36520)MOD 3652));
SET v = v + 1;
END WHILE;
END;
//
CALL load_part_tab;
INSERT INTO no_part_tab SELECT * FROM part_tab;
-- 5. 測試查詢效率
SELECT COUNT(*) FROM part_tab WHERE c3 > DATE '1995-01-01'AND c3 < DATE '1995-12-31';
SELECT COUNT(*) FROM no_part_tab WHERE c3 > DATE '1995-01-01'AND c3 < DATE '1995-12-31';
-- 6. 通過explain語句來分析執行情況
EXPLAIN SELECT COUNT(*) FROM part_tab WHERE c3 > DATE '1995-01-01'AND c3 < DATE '1995-12-31';
EXPLAIN SELECT COUNT(*) FROM no_part_tab WHERE c3 > DATE '1995-01-01'AND c3 < DATE '1995-12-31';
到此,相信大家對“MYSQL表分區測試命令”有了更深的了解,不妨來實際操作一番吧!這里是億速云網站,更多相關內容可以進入相關頻道進行查詢,關注我們,繼續學習!
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。