JavaScriptを有効にしてください

【Mysql】指定したパーティションのみを検索する

 ·  ☕ 1 分で読めます

【Mysql】指定したパーティションのみを検索する

Mysqlで指定したパーティションのみを検索する方法メモ。

パーティションを指定して検索する

以下の方法で指定したパーティションのみの検索が可能です。

1
2
3
4
SELECT
    * 
FROM
    [TABLE_NAME] PARTITION ([PARTITION_NAME]);

サンプルテーブルの作成

 1
 2
 3
 4
 5
 6
 7
 8
 9
10
11
CREATE TABLE `sample` ( 
    `id` bigint(20) unsigned NOT NULL AUTO_INCREMENT ,
    `num` decimal (6, 4) DEFAULT 0 NOT NULL ,
    PRIMARY KEY (`id`, `num`)
) ENGINE = InnoDB DEFAULT CHARSET = utf8mb4
PARTITION BY RANGE (FLOOR (`num`))( 
    PARTITION p0 VALUES LESS THAN (10),
    PARTITION p1 VALUES LESS THAN (20),
    PARTITION p2 VALUES LESS THAN (30),
    PARTITION p3 VALUES LESS THAN MAXVALUE
);

データを入れる

作成したテーブルにデータを入れてみます。

1
2
3
4
5
6
7
8
9
INSERT INTO `sample` (`num`) 
values (5)
, (10)
, (15)
, (20)
, (25)
, (30)
, (35)
, (40);

実行

パーティションを指定してSQLを実行してみます。

1
2
3
4
SELECT
    * 
FROM
    sample PARTITION (p0);

実行結果

idnum
15.0000

条件がない状態ですが全件出ずに指定のパーティションのデータのみ出てきます。

応用編

複数のパーティションを同時に検索する場合は以下のようにカンマ区切りで指定することが可能です。

1
2
3
4
SELECT
    * 
FROM
    sample PARTITION (p0, p3)

実行結果

idnum
15.0000
630.0000
735.0000
840.0000

参考

共有

こぴぺたん
著者
こぴぺたん
Copy & Paste Engineer