From: | Amit Langote <Langote_Amit_f8(at)lab(dot)ntt(dot)co(dot)jp> |
---|---|
To: | Dmitry Ivanov <d(dot)ivanov(at)postgrespro(dot)ru> |
Cc: | Robert Haas <robertmhaas(at)gmail(dot)com>, Michael Paquier <michael(dot)paquier(at)gmail(dot)com>, Andres Freund <andres(at)anarazel(dot)de>, Erik Rijkers <er(at)xs4all(dot)nl>, Amit Langote <amitlangote09(at)gmail(dot)com>, Rajkumar Raghuwanshi <rajkumar(dot)raghuwanshi(at)enterprisedb(dot)com>, Ashutosh Bapat <ashutosh(dot)bapat(at)enterprisedb(dot)com>, Pg Hackers <pgsql-hackers(at)postgresql(dot)org>, pgsql-hackers-owner(at)postgresql(dot)org |
Subject: | Re: Declarative partitioning - another take |
Date: | 2016-12-13 06:58:59 |
Message-ID: | f0857685-a232-1fb3-4dcd-cbc2ffa55ad8@lab.ntt.co.jp |
Views: | Raw Message | Whole Thread | Download mbox | Resend email |
Thread: | |
Lists: | pgsql-hackers |
Hi,
On 2016/12/13 2:45, Dmitry Ivanov wrote:
> Huh, this code is broken as well. We have to ignore partitions that don't
> have any subpartitions. Patch is attached below (v2).
Good catch and thanks a lot for the patch! I have revised it a bit and
added some explanatory comments to that function.
Attaching the above patch, along with some other patches posted earlier,
and one more patch fixing another bug I found. Patch descriptions follow:
0001-Miscallaneous-code-and-comment-improvements.patch
Fixes some obsolete comments while improving others. Also, implements
some of Tomas Vondra's review comments.
0002-Miscallaneous-documentation-improvements.patch
Fixes inconsistencies and improves some examples in the documentation.
Also, mentions the limitation regarding row movement.
0003-Invalidate-the-parent-s-relcache-after-partition-cre.patch
Fixes a bug reported by Tomas, whereby a parent's relcache was not
invalidated after creation of a new partition using CREATE TABLE PARTITION
OF. This resulted in tuple-routing code not being to able to find a
partition that was created by the last command in a given transaction.
0004-Fix-a-bug-of-insertion-into-an-internal-partition.patch
Fixes a bug I found this morning, whereby an internal partition's
constraint would not be enforced if it is targeted directly. See example
below:
create table p (a int, b char) partition by range (a);
create table p1 partition of p for values from (1) to (10) partition by
list (b);
create table p1a partition of p1 for values in ('a');
insert into p1 values (0, 'a'); -- should fail, but doesn't
0005-Fix-a-tuple-routing-bug-in-multi-level-partitioned-t.patch
Fixes a bug discovered by Dmitry Ivanov, whereby wrong indexes were
assigned to the partitions of lower levels (level > 1), causing spurious
"partition not found" error as demonstrated in his email [1].
Sorry about sending some of these patches repeatedly though.
Thanks,
Amit
[1]
https://www.postgresql.org/message-id/e6c56fe9-4b87-4f64-ac6f-bc99675f3f9e%40postgrespro.ru
Attachment | Content-Type | Size |
---|---|---|
0001-Miscallaneous-code-and-comment-improvements.patch | text/x-diff | 8.3 KB |
0002-Miscallaneous-documentation-improvements.patch | text/x-diff | 6.0 KB |
0003-Invalidate-the-parent-s-relcache-after-partition-cre.patch | text/x-diff | 1.3 KB |
0004-Fix-a-bug-of-insertion-into-an-internal-partition.patch | text/x-diff | 8.2 KB |
0005-Fix-a-tuple-routing-bug-in-multi-level-partitioned-t.patch | text/x-diff | 3.4 KB |
From | Date | Subject | |
---|---|---|---|
Next Message | amul sul | 2016-12-13 07:55:24 | Re: pg_background contrib module proposal |
Previous Message | Dilip Kumar | 2016-12-13 06:36:33 | Re: Parallel bitmap heap scan |