pg 10多级分区表(range_list)配置查询

发布时间:2020-07-03 02:42:18 作者:pgmia
来源:网络 阅读:1228

-- define partitioned table: t_range_list

create table t_range_list(id bigserial, tenant_id int, crt_time timestamp) partition by list ( mod(tenant_id, 10));



-- level 1 : list-- list ( mod(tenant_id, 10))

create table t_range_list_0 partition of t_range_list (id, tenant_id, crt_time ) for values in (0) partition by range (crt_time);

create table t_range_list_1 partition of t_range_list (id, tenant_id, crt_time ) for values in (1) partition by range (crt_time); 

create table t_range_list_2 partition of t_range_list (id, tenant_id, crt_time ) for values in (2) partition by range (crt_time); 

create table t_range_list_3 partition of t_range_list (id, tenant_id, crt_time ) for values in (3) partition by range (crt_time);

create table t_range_list_4 partition of t_range_list (id, tenant_id, crt_time ) for values in (4) partition by range (crt_time);

create table t_range_list_5 partition of t_range_list (id, tenant_id, crt_time ) for values in (5) partition by range (crt_time);

create table t_range_list_6 partition of t_range_list (id, tenant_id, crt_time ) for values in (6) partition by range (crt_time);

create table t_range_list_7 partition of t_range_list (id, tenant_id, crt_time ) for values in (7) partition by range (crt_time);

create table t_range_list_8 partition of t_range_list (id, tenant_id, crt_time ) for values in (8) partition by range (crt_time);

create table t_range_list_9 partition of t_range_list (id, tenant_id, crt_time ) for values in (9) partition by range (crt_time);



-- level 2 : range-- range (crt_time)

-- t_range_list_0

create table t_range_list_0_201701 partition of t_range_list_0 (id  primary key, tenant_id , crt_time ) for values from ('2017-01-01') to ('2017-02-01');

create table t_range_list_0_201702 partition of t_range_list_0 (id  primary key, tenant_id , crt_time ) for values from ('2017-02-01') to ('2017-03-01');

create table t_range_list_0_201703 partition of t_range_list_0 (id  primary key, tenant_id , crt_time ) for values from ('2017-03-01') to ('2017-04-01');

create table t_range_list_0_201704 partition of t_range_list_0 (id  primary key, tenant_id , crt_time ) for values from ('2017-04-01') to ('2017-05-01');

create table t_range_list_0_201705 partition of t_range_list_0 (id  primary key, tenant_id , crt_time ) for values from ('2017-05-01') to ('2017-06-01');

create table t_range_list_0_201706 partition of t_range_list_0 (id  primary key, tenant_id , crt_time ) for values from ('2017-06-01') to ('2017-07-01');

create table t_range_list_0_201707 partition of t_range_list_0 (id  primary key, tenant_id , crt_time ) for values from ('2017-07-01') to ('2017-08-01');

create table t_range_list_0_201708 partition of t_range_list_0 (id  primary key, tenant_id , crt_time ) for values from ('2017-08-01') to ('2017-09-01');

create table t_range_list_0_201709 partition of t_range_list_0 (id  primary key, tenant_id , crt_time ) for values from ('2017-09-01') to ('2017-10-01');

create table t_range_list_0_201710 partition of t_range_list_0 (id  primary key, tenant_id , crt_time ) for values from ('2017-10-01') to ('2017-11-01');

create table t_range_list_0_201711 partition of t_range_list_0 (id  primary key, tenant_id , crt_time ) for values from ('2017-11-01') to ('2017-12-01');

create table t_range_list_0_201712 partition of t_range_list_0 (id  primary key, tenant_id , crt_time ) for values from ('2017-12-01') to ('2018-01-01');


-- t_range_list_1

create table t_range_list_1_201701 partition of t_range_list_1 (id  primary key, tenant_id , crt_time ) for values from ('2017-01-01') to ('2017-02-01');

create table t_range_list_1_201702 partition of t_range_list_1 (id  primary key, tenant_id , crt_time ) for values from ('2017-02-01') to ('2017-03-01');

create table t_range_list_1_201703 partition of t_range_list_1 (id  primary key, tenant_id , crt_time ) for values from ('2017-03-01') to ('2017-04-01');

create table t_range_list_1_201704 partition of t_range_list_1 (id  primary key, tenant_id , crt_time ) for values from ('2017-04-01') to ('2017-05-01');

create table t_range_list_1_201705 partition of t_range_list_1 (id  primary key, tenant_id , crt_time ) for values from ('2017-05-01') to ('2017-06-01');

create table t_range_list_1_201706 partition of t_range_list_1 (id  primary key, tenant_id , crt_time ) for values from ('2017-06-01') to ('2017-07-01');

create table t_range_list_1_201707 partition of t_range_list_1 (id  primary key, tenant_id , crt_time ) for values from ('2017-07-01') to ('2017-08-01');

create table t_range_list_1_201708 partition of t_range_list_1 (id  primary key, tenant_id , crt_time ) for values from ('2017-08-01') to ('2017-09-01');

create table t_range_list_1_201709 partition of t_range_list_1 (id  primary key, tenant_id , crt_time ) for values from ('2017-09-01') to ('2017-10-01');

create table t_range_list_1_201710 partition of t_range_list_1 (id  primary key, tenant_id , crt_time ) for values from ('2017-10-01') to ('2017-11-01');

create table t_range_list_1_201711 partition of t_range_list_1 (id  primary key, tenant_id , crt_time ) for values from ('2017-11-01') to ('2017-12-01');

create table t_range_list_1_201712 partition of t_range_list_1 (id  primary key, tenant_id , crt_time ) for values from ('2017-12-01') to ('2018-01-01');


-- t_range_list_2;

create table t_range_list_2_201701 partition of t_range_list_2 (id  primary key, tenant_id , crt_time ) for values from ('2017-01-01') to ('2017-02-01');

create table t_range_list_2_201702 partition of t_range_list_2 (id  primary key, tenant_id , crt_time ) for values from ('2017-02-01') to ('2017-03-01');

create table t_range_list_2_201703 partition of t_range_list_2 (id  primary key, tenant_id , crt_time ) for values from ('2017-03-01') to ('2017-04-01');

create table t_range_list_2_201704 partition of t_range_list_2 (id  primary key, tenant_id , crt_time ) for values from ('2017-04-01') to ('2017-05-01');

create table t_range_list_2_201705 partition of t_range_list_2 (id  primary key, tenant_id , crt_time ) for values from ('2017-05-01') to ('2017-06-01');

create table t_range_list_2_201706 partition of t_range_list_2 (id  primary key, tenant_id , crt_time ) for values from ('2017-06-01') to ('2017-07-01');

create table t_range_list_2_201707 partition of t_range_list_2 (id  primary key, tenant_id , crt_time ) for values from ('2017-07-01') to ('2017-08-01');

create table t_range_list_2_201708 partition of t_range_list_2 (id  primary key, tenant_id , crt_time ) for values from ('2017-08-01') to ('2017-09-01');

create table t_range_list_2_201709 partition of t_range_list_2 (id  primary key, tenant_id , crt_time ) for values from ('2017-09-01') to ('2017-10-01');

create table t_range_list_2_201710 partition of t_range_list_2 (id  primary key, tenant_id , crt_time ) for values from ('2017-10-01') to ('2017-11-01');

create table t_range_list_2_201711 partition of t_range_list_2 (id  primary key, tenant_id , crt_time ) for values from ('2017-11-01') to ('2017-12-01');

create table t_range_list_2_201712 partition of t_range_list_2 (id  primary key, tenant_id , crt_time ) for values from ('2017-12-01') to ('2018-01-01');





-- t_range_list_3;

create table t_range_list_3_201701 partition of t_range_list_3 (id  primary key, tenant_id , crt_time ) for values from ('2017-01-01') to ('2017-02-01');

create table t_range_list_3_201702 partition of t_range_list_3 (id  primary key, tenant_id , crt_time ) for values from ('2017-02-01') to ('2017-03-01');

create table t_range_list_3_201703 partition of t_range_list_3 (id  primary key, tenant_id , crt_time ) for values from ('2017-03-01') to ('2017-04-01');

create table t_range_list_3_201704 partition of t_range_list_3 (id  primary key, tenant_id , crt_time ) for values from ('2017-04-01') to ('2017-05-01');

create table t_range_list_3_201705 partition of t_range_list_3 (id  primary key, tenant_id , crt_time ) for values from ('2017-05-01') to ('2017-06-01');

create table t_range_list_3_201706 partition of t_range_list_3 (id  primary key, tenant_id , crt_time ) for values from ('2017-06-01') to ('2017-07-01');

create table t_range_list_3_201707 partition of t_range_list_3 (id  primary key, tenant_id , crt_time ) for values from ('2017-07-01') to ('2017-08-01');

create table t_range_list_3_201708 partition of t_range_list_3 (id  primary key, tenant_id , crt_time ) for values from ('2017-08-01') to ('2017-09-01');

create table t_range_list_3_201709 partition of t_range_list_3 (id  primary key, tenant_id , crt_time ) for values from ('2017-09-01') to ('2017-10-01');

create table t_range_list_3_201710 partition of t_range_list_3 (id  primary key, tenant_id , crt_time ) for values from ('2017-10-01') to ('2017-11-01');

create table t_range_list_3_201711 partition of t_range_list_3 (id  primary key, tenant_id , crt_time ) for values from ('2017-11-01') to ('2017-12-01');

create table t_range_list_3_201712 partition of t_range_list_3 (id  primary key, tenant_id , crt_time ) for values from ('2017-12-01') to ('2018-01-01');



-- t_range_list_4;

create table t_range_list_4_201701 partition of t_range_list_4 (id  primary key, tenant_id , crt_time ) for values from ('2017-01-01') to ('2017-02-01');

create table t_range_list_4_201702 partition of t_range_list_4 (id  primary key, tenant_id , crt_time ) for values from ('2017-02-01') to ('2017-03-01');

create table t_range_list_4_201703 partition of t_range_list_4 (id  primary key, tenant_id , crt_time ) for values from ('2017-03-01') to ('2017-04-01');

create table t_range_list_4_201704 partition of t_range_list_4 (id  primary key, tenant_id , crt_time ) for values from ('2017-04-01') to ('2017-05-01');

create table t_range_list_4_201705 partition of t_range_list_4 (id  primary key, tenant_id , crt_time ) for values from ('2017-05-01') to ('2017-06-01');

create table t_range_list_4_201706 partition of t_range_list_4 (id  primary key, tenant_id , crt_time ) for values from ('2017-06-01') to ('2017-07-01');

create table t_range_list_4_201707 partition of t_range_list_4 (id  primary key, tenant_id , crt_time ) for values from ('2017-07-01') to ('2017-08-01');

create table t_range_list_4_201708 partition of t_range_list_4 (id  primary key, tenant_id , crt_time ) for values from ('2017-08-01') to ('2017-09-01');

create table t_range_list_4_201709 partition of t_range_list_4 (id  primary key, tenant_id , crt_time ) for values from ('2017-09-01') to ('2017-10-01');

create table t_range_list_4_201710 partition of t_range_list_4 (id  primary key, tenant_id , crt_time ) for values from ('2017-10-01') to ('2017-11-01');

create table t_range_list_4_201711 partition of t_range_list_4 (id  primary key, tenant_id , crt_time ) for values from ('2017-11-01') to ('2017-12-01');

create table t_range_list_4_201712 partition of t_range_list_4 (id  primary key, tenant_id , crt_time ) for values from ('2017-12-01') to ('2018-01-01');


-- t_range_list_5;

create table t_range_list_5_201701 partition of t_range_list_5 (id  primary key, tenant_id , crt_time ) for values from ('2017-01-01') to ('2017-02-01');

create table t_range_list_5_201702 partition of t_range_list_5 (id  primary key, tenant_id , crt_time ) for values from ('2017-02-01') to ('2017-03-01');

create table t_range_list_5_201703 partition of t_range_list_5 (id  primary key, tenant_id , crt_time ) for values from ('2017-03-01') to ('2017-04-01');

create table t_range_list_5_201704 partition of t_range_list_5 (id  primary key, tenant_id , crt_time ) for values from ('2017-04-01') to ('2017-05-01');

create table t_range_list_5_201705 partition of t_range_list_5 (id  primary key, tenant_id , crt_time ) for values from ('2017-05-01') to ('2017-06-01');

create table t_range_list_5_201706 partition of t_range_list_5 (id  primary key, tenant_id , crt_time ) for values from ('2017-06-01') to ('2017-07-01');

create table t_range_list_5_201707 partition of t_range_list_5 (id  primary key, tenant_id , crt_time ) for values from ('2017-07-01') to ('2017-08-01');

create table t_range_list_5_201708 partition of t_range_list_5 (id  primary key, tenant_id , crt_time ) for values from ('2017-08-01') to ('2017-09-01');

create table t_range_list_5_201709 partition of t_range_list_5 (id  primary key, tenant_id , crt_time ) for values from ('2017-09-01') to ('2017-10-01');

create table t_range_list_5_201710 partition of t_range_list_5 (id  primary key, tenant_id , crt_time ) for values from ('2017-10-01') to ('2017-11-01');

create table t_range_list_5_201711 partition of t_range_list_5 (id  primary key, tenant_id , crt_time ) for values from ('2017-11-01') to ('2017-12-01');

create table t_range_list_5_201712 partition of t_range_list_5 (id  primary key, tenant_id , crt_time ) for values from ('2017-12-01') to ('2018-01-01');


-- t_range_list_6;

create table t_range_list_6_201701 partition of t_range_list_6 (id  primary key, tenant_id , crt_time ) for values from ('2017-01-01') to ('2017-02-01');

create table t_range_list_6_201702 partition of t_range_list_6 (id  primary key, tenant_id , crt_time ) for values from ('2017-02-01') to ('2017-03-01');

create table t_range_list_6_201703 partition of t_range_list_6 (id  primary key, tenant_id , crt_time ) for values from ('2017-03-01') to ('2017-04-01');

create table t_range_list_6_201704 partition of t_range_list_6 (id  primary key, tenant_id , crt_time ) for values from ('2017-04-01') to ('2017-05-01');

create table t_range_list_6_201705 partition of t_range_list_6 (id  primary key, tenant_id , crt_time ) for values from ('2017-05-01') to ('2017-06-01');

create table t_range_list_6_201706 partition of t_range_list_6 (id  primary key, tenant_id , crt_time ) for values from ('2017-06-01') to ('2017-07-01');

create table t_range_list_6_201707 partition of t_range_list_6 (id  primary key, tenant_id , crt_time ) for values from ('2017-07-01') to ('2017-08-01');

create table t_range_list_6_201708 partition of t_range_list_6 (id  primary key, tenant_id , crt_time ) for values from ('2017-08-01') to ('2017-09-01');

create table t_range_list_6_201709 partition of t_range_list_6 (id  primary key, tenant_id , crt_time ) for values from ('2017-09-01') to ('2017-10-01');

create table t_range_list_6_201710 partition of t_range_list_6 (id  primary key, tenant_id , crt_time ) for values from ('2017-10-01') to ('2017-11-01');

create table t_range_list_6_201711 partition of t_range_list_6 (id  primary key, tenant_id , crt_time ) for values from ('2017-11-01') to ('2017-12-01');

create table t_range_list_6_201712 partition of t_range_list_6 (id  primary key, tenant_id , crt_time ) for values from ('2017-12-01') to ('2018-01-01');


-- t_range_list_7;

create table t_range_list_7_201701 partition of t_range_list_7 (id  primary key, tenant_id , crt_time ) for values from ('2017-01-01') to ('2017-02-01');

create table t_range_list_7_201702 partition of t_range_list_7 (id  primary key, tenant_id , crt_time ) for values from ('2017-02-01') to ('2017-03-01');

create table t_range_list_7_201703 partition of t_range_list_7 (id  primary key, tenant_id , crt_time ) for values from ('2017-03-01') to ('2017-04-01');

create table t_range_list_7_201704 partition of t_range_list_7 (id  primary key, tenant_id , crt_time ) for values from ('2017-04-01') to ('2017-05-01');

create table t_range_list_7_201705 partition of t_range_list_7 (id  primary key, tenant_id , crt_time ) for values from ('2017-05-01') to ('2017-06-01');

create table t_range_list_7_201706 partition of t_range_list_7 (id  primary key, tenant_id , crt_time ) for values from ('2017-06-01') to ('2017-07-01');

create table t_range_list_7_201707 partition of t_range_list_7 (id  primary key, tenant_id , crt_time ) for values from ('2017-07-01') to ('2017-08-01');

create table t_range_list_7_201708 partition of t_range_list_7 (id  primary key, tenant_id , crt_time ) for values from ('2017-08-01') to ('2017-09-01');

create table t_range_list_7_201709 partition of t_range_list_7 (id  primary key, tenant_id , crt_time ) for values from ('2017-09-01') to ('2017-10-01');

create table t_range_list_7_201710 partition of t_range_list_7 (id  primary key, tenant_id , crt_time ) for values from ('2017-10-01') to ('2017-11-01');

create table t_range_list_7_201711 partition of t_range_list_7 (id  primary key, tenant_id , crt_time ) for values from ('2017-11-01') to ('2017-12-01');

create table t_range_list_7_201712 partition of t_range_list_7 (id  primary key, tenant_id , crt_time ) for values from ('2017-12-01') to ('2018-01-01');


-- t_range_list_8;

create table t_range_list_8_201701 partition of t_range_list_8 (id  primary key, tenant_id , crt_time ) for values from ('2017-01-01') to ('2017-02-01');

create table t_range_list_8_201702 partition of t_range_list_8 (id  primary key, tenant_id , crt_time ) for values from ('2017-02-01') to ('2017-03-01');

create table t_range_list_8_201703 partition of t_range_list_8 (id  primary key, tenant_id , crt_time ) for values from ('2017-03-01') to ('2017-04-01');

create table t_range_list_8_201704 partition of t_range_list_8 (id  primary key, tenant_id , crt_time ) for values from ('2017-04-01') to ('2017-05-01');

create table t_range_list_8_201705 partition of t_range_list_8 (id  primary key, tenant_id , crt_time ) for values from ('2017-05-01') to ('2017-06-01');

create table t_range_list_8_201706 partition of t_range_list_8 (id  primary key, tenant_id , crt_time ) for values from ('2017-06-01') to ('2017-07-01');

create table t_range_list_8_201707 partition of t_range_list_8 (id  primary key, tenant_id , crt_time ) for values from ('2017-07-01') to ('2017-08-01');

create table t_range_list_8_201708 partition of t_range_list_8 (id  primary key, tenant_id , crt_time ) for values from ('2017-08-01') to ('2017-09-01');

create table t_range_list_8_201709 partition of t_range_list_8 (id  primary key, tenant_id , crt_time ) for values from ('2017-09-01') to ('2017-10-01');

create table t_range_list_8_201710 partition of t_range_list_8 (id  primary key, tenant_id , crt_time ) for values from ('2017-10-01') to ('2017-11-01');

create table t_range_list_8_201711 partition of t_range_list_8 (id  primary key, tenant_id , crt_time ) for values from ('2017-11-01') to ('2017-12-01');

create table t_range_list_8_201712 partition of t_range_list_8 (id  primary key, tenant_id , crt_time ) for values from ('2017-12-01') to ('2018-01-01');


-- t_range_list_9;

create table t_range_list_9_201701 partition of t_range_list_9 (id  primary key, tenant_id , crt_time ) for values from ('2017-01-01') to ('2017-02-01');

create table t_range_list_9_201702 partition of t_range_list_9 (id  primary key, tenant_id , crt_time ) for values from ('2017-02-01') to ('2017-03-01');

create table t_range_list_9_201703 partition of t_range_list_9 (id  primary key, tenant_id , crt_time ) for values from ('2017-03-01') to ('2017-04-01');

create table t_range_list_9_201704 partition of t_range_list_9 (id  primary key, tenant_id , crt_time ) for values from ('2017-04-01') to ('2017-05-01');

create table t_range_list_9_201705 partition of t_range_list_9 (id  primary key, tenant_id , crt_time ) for values from ('2017-05-01') to ('2017-06-01');

create table t_range_list_9_201706 partition of t_range_list_9 (id  primary key, tenant_id , crt_time ) for values from ('2017-06-01') to ('2017-07-01');

create table t_range_list_9_201707 partition of t_range_list_9 (id  primary key, tenant_id , crt_time ) for values from ('2017-07-01') to ('2017-08-01');

create table t_range_list_9_201708 partition of t_range_list_9 (id  primary key, tenant_id , crt_time ) for values from ('2017-08-01') to ('2017-09-01');

create table t_range_list_9_201709 partition of t_range_list_9 (id  primary key, tenant_id , crt_time ) for values from ('2017-09-01') to ('2017-10-01');

create table t_range_list_9_201710 partition of t_range_list_9 (id  primary key, tenant_id , crt_time ) for values from ('2017-10-01') to ('2017-11-01');

create table t_range_list_9_201711 partition of t_range_list_9 (id  primary key, tenant_id , crt_time ) for values from ('2017-11-01') to ('2017-12-01');

create table t_range_list_9_201712 partition of t_range_list_9 (id  primary key, tenant_id , crt_time ) for values from ('2017-12-01') to ('2018-01-01');


-- insert test data:

insert into t_range_list(tenant_id,crt_time) values(10110,'2017-01-01 09:10:30'),(10111,'2017-02-01 09:10:30'),(10112,'2017-03-01 09:10:30'),(10113,'2017-04-01 09:10:30'),

(10114,'2017-05-01 09:10:30'),(10115,'2017-06-01 09:10:30'),(10116,'2017-07-01 09:10:30'),(10118,'2017-08-01 09:10:30'),

(10119,'2017-09-01 09:10:30'),(10120,'2017-10-01 09:10:30'),(10121,'2017-11-01 09:10:30'),(10122,'2017-12-01 09:10:30')


--excute SQL Select

pdb=# explain analyze select * from t_range_list

where mod(tenant_id, 10)=mod(10112, 10)

and crt_time='2017-03-01 09:10:30';

                                                      QUERY PLAN                                                       

-----------------------------------------------------------------------------------------------------------------------

 Append  (cost=0.00..39.75 rows=1 width=20) (actual time=0.015..0.016 rows=1 loops=1)

   ->  Seq Scan on t_range_list_2_201703  (cost=0.00..39.75 rows=1 width=20) (actual time=0.014..0.015 rows=1 loops=1)

         Filter: ((crt_time = '2017-03-01 09:10:30'::timestamp without time zone) AND (mod(tenant_id, 10) = 2))

 Planning time: 5.177 ms

 Execution time: 0.047 ms

(5 rows)


pdb=# 


推荐阅读:
  1. PG Logical Replication 逻辑复制
  2. PostgreSQL DBA( - PG 12 Improv

免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。

pg10 range_list part lis st

上一篇:路由器+交换机基本命令配置参数

下一篇:RedHat使用yum命令时提示not registered错误的解决方法

相关阅读

您好,登录后才能下订单哦!

密码登录
登录注册
其他方式登录
点击 登录注册 即表示同意《亿速云用户服务条款》