我在Postgres有一張大桌子。Postgres分區修剪
表名是bigtable
,列有:
integer |timestamp |xxx |xxx |...|xxx
category_id|capture_time|col1|col2|...|colN
我已經劃分的capture_time列CATEGORY_ID和日期部分的模10表。
的分區表是這樣的:
CREATE TABLE myschema.bigtable_d000h0(
CHECK (category_id%10=0 AND capture_time >= DATE '2012-01-01' AND capture_time < DATE '2012-01-02')
) INHERITS (myschema.bigtable);
CREATE TABLE myschema.bigtable_d000h1(
CHECK (category_id%10=1 AND capture_time >= DATE '2012-01-01' AND capture_time < DATE '2012-01-02')
) INHERITS (myschema.bigtable);
當我運行在where子句中使用CATEGORY_ID和capture_time查詢,預期分區不修剪。
explain select * from bigtable where capture_time >= '2012-01-01' and capture_time < '2012-01-02' and category_id=100;
"Result (cost=0.00..9476.87 rows=1933 width=216)"
" -> Append (cost=0.00..9476.87 rows=1933 width=216)"
" -> Seq Scan on bigtable (cost=0.00..0.00 rows=1 width=210)"
" Filter: ((capture_time >= '2012-01-01 00:00:00'::timestamp without time zone) AND (capture_time < '2012-01-02 00:00:00'::timestamp without time zone) AND (category_id = 100))"
" -> Seq Scan on bigtable_d000h0 bigtable (cost=0.00..1921.63 rows=1923 width=216)"
" Filter: ((capture_time >= '2012-01-01 00:00:00'::timestamp without time zone) AND (capture_time < '2012-01-02 00:00:00'::timestamp without time zone) AND (category_id = 100))"
" -> Seq Scan on bigtable_d000h1 bigtable (cost=0.00..776.93 rows=1 width=218)"
" Filter: ((capture_time >= '2012-01-01 00:00:00'::timestamp without time zone) AND (capture_time < '2012-01-02 00:00:00'::timestamp without time zone) AND (category_id = 100))"
" -> Seq Scan on bigtable_d000h2 bigtable (cost=0.00..974.47 rows=1 width=216)"
" Filter: ((capture_time >= '2012-01-01 00:00:00'::timestamp without time zone) AND (capture_time < '2012-01-02 00:00:00'::timestamp without time zone) AND (category_id = 100))"
" -> Seq Scan on bigtable_d000h3 bigtable (cost=0.00..1351.92 rows=1 width=214)"
" Filter: ((capture_time >= '2012-01-01 00:00:00'::timestamp without time zone) AND (capture_time < '2012-01-02 00:00:00'::timestamp without time zone) AND (category_id = 100))"
" -> Seq Scan on bigtable_d000h4 bigtable (cost=0.00..577.04 rows=1 width=217)"
" Filter: ((capture_time >= '2012-01-01 00:00:00'::timestamp without time zone) AND (capture_time < '2012-01-02 00:00:00'::timestamp without time zone) AND (category_id = 100))"
" -> Seq Scan on bigtable_d000h5 bigtable (cost=0.00..360.67 rows=1 width=219)"
" Filter: ((capture_time >= '2012-01-01 00:00:00'::timestamp without time zone) AND (capture_time < '2012-01-02 00:00:00'::timestamp without time zone) AND (category_id = 100))"
" -> Seq Scan on bigtable_d000h6 bigtable (cost=0.00..1778.18 rows=1 width=214)"
" Filter: ((capture_time >= '2012-01-01 00:00:00'::timestamp without time zone) AND (capture_time < '2012-01-02 00:00:00'::timestamp without time zone) AND (category_id = 100))"
" -> Seq Scan on bigtable_d000h7 bigtable (cost=0.00..315.82 rows=1 width=216)"
" Filter: ((capture_time >= '2012-01-01 00:00:00'::timestamp without time zone) AND (capture_time < '2012-01-02 00:00:00'::timestamp without time zone) AND (category_id = 100))"
" -> Seq Scan on bigtable_d000h8 bigtable (cost=0.00..372.06 rows=1 width=219)"
" Filter: ((capture_time >= '2012-01-01 00:00:00'::timestamp without time zone) AND (capture_time < '2012-01-02 00:00:00'::timestamp without time zone) AND (category_id = 100))"
" -> Seq Scan on bigtable_d000h9 bigtable (cost=0.00..1048.16 rows=1 width=215)"
" Filter: ((capture_time >= '2012-01-01 00:00:00'::timestamp without time zone) AND (capture_time < '2012-01-02 00:00:00'::timestamp without time zone) AND (category_id = 100))"
但是,如果我在where子句中添加的確切模標準(category_id%10=0
),它完美
explain select * from bigtable where capture_time >= '2012-01-01' and capture_time < '2012-01-02' and category_id=100 and category_id%10=0;
"Result (cost=0.00..2154.09 rows=11 width=215)"
" -> Append (cost=0.00..2154.09 rows=11 width=215)"
" -> Seq Scan on bigtable (cost=0.00..0.00 rows=1 width=210)"
" Filter: ((capture_time >= '2012-01-01 00:00:00'::timestamp without time zone) AND (capture_time < '2012-01-02 00:00:00'::timestamp without time zone) AND (category_id = 100) AND ((category_id % 10) = 0))"
" -> Seq Scan on bigtable_d000h0 bigtable (cost=0.00..2154.09 rows=10 width=216)"
" Filter: ((capture_time >= '2012-01-01 00:00:00'::timestamp without time zone) AND (capture_time < '2012-01-02 00:00:00'::timestamp without time zone) AND (category_id = 100) AND ((category_id % 10) = 0))"
有沒有什麼辦法讓分區修剪工作正常,而無需添加模每個查詢中的條件?
?我認爲規劃師在9.x – 2012-04-03 17:31:16
中進行了分區方面的一些改進。您可以使約束略少一點:'CHECK(category_id%10 = 1 AND date_trunc('month',capture_time)='2012-01 -01':: date)' – 2012-04-03 17:40:16
@a_horse_with_no_name我正在使用9.1 – Dojo 2012-04-03 17:47:19