使用 EXPLAIN PARTITIONS 语句可以了解查询涉及了哪些分区。这有助于诊断查询性能问题,并确保查询正确地利用了分区。

示例:创建分区表并插入数据

首先,我们创建一个分区表 range_columns,并插入一些示例数据。

创建表
CREATE TABLE range_columns (
    id INT,
    hiredate DATETIME
)
PARTITION BY RANGE COLUMNS(hiredate) (
    PARTITION p1 VALUES LESS THAN ('2015-12-02'),
    PARTITION p2 VALUES LESS THAN ('2015-12-03'),
    PARTITION p3 VALUES LESS THAN ('2015-12-04'),
    PARTITION p4 VALUES LESS THAN ('2015-12-05'),
    PARTITION p5 VALUES LESS THAN ('2015-12-06'),
    PARTITION p6 VALUES LESS THAN ('2015-12-07'),
    PARTITION p7 VALUES LESS THAN ('2015-12-08'),
    PARTITION p8 VALUES LESS THAN ('2015-12-09'),
    PARTITION p9 VALUES LESS THAN ('2015-12-10'),
    PARTITION p10 VALUES LESS THAN ('2015-12-11')
);
插入数据
INSERT INTO range_columns (id, hiredate)
VALUES (1, '2015-12-01 10:00:00'), -- 应该进入 p1
       (2, '2015-12-02 11:00:00'), -- 应该进入 p1
       (3, '2015-12-03 12:00:00'), -- 应该进入 p2
       (4, '2015-12-04 13:00:00'), -- 应该进入 p3
       (5, '2015-12-05 14:00:00'), -- 应该进入 p4
       (6, '2015-12-06 15:00:00'), -- 应该进入 p5
       (7, '2015-12-07 16:00:00'), -- 应该进入 p6
       (8, '2015-12-08 17:00:00'), -- 应该进入 p7
       (9, '2015-12-09 18:00:00'), -- 应该进入 p8
       (10, '2015-12-10 19:00:00'); -- 应该进入 p10

使用 EXPLAIN PARTITIONS 检查查询计划

要检查查询涉及了哪些分区,可以使用 EXPLAIN PARTITIONS 语句。这将提供有关查询执行计划的信息,包括涉及的分区。

示例查询

假设我们要查询 hiredate2015-12-012015-12-07 之间的数据:

EXPLAIN PARTITIONS SELECT * FROM range_columns
WHERE hiredate >= '2015-12-01' AND hiredate <= '2015-12-07';

输出结果解释

执行上述 EXPLAIN PARTITIONS 语句后,您将看到类似于以下的输出:

+----+-------------+-------+--------+---------------+---------+---------+-------------------+---------+--------------------------+
| id | select_type | table | type   | possible_keys | key     | key_len | ref               | rows    | Extra                    |
+----+-------------+-------+--------+---------------+---------+---------+-------------------+---------+--------------------------+
|  1 | SIMPLE      | t1    | range  | hiredate      | hiredate | 5       | NULL              | 10      | Using where; Using index |
|    |             |       |        |               |         |         |                   |         | Partitions p1, p2, p3, p4, p5, p6 |
+----+-------------+-------+--------+---------------+---------+---------+-------------------+---------+--------------------------+

在这个输出中,Extra 列显示了涉及的分区信息。例如:

Partitions p1, p2, p3, p4, p5, p6

这意味着查询涉及了 p1p6 这六个分区。

总结

使用 EXPLAIN PARTITIONS 语句可以帮助您了解查询涉及了哪些分区,这对于诊断查询性能问题和确保查询正确利用分区非常重要。通过这种方式,你可以验证查询是否正确地命中了预期的分区,并评估查询的执行效率。