summaryrefslogtreecommitdiff
path: root/contrib/btree_gist/sql/date.sql
diff options
context:
space:
mode:
authorTom Lane <tgl@sss.pgh.pa.us>2019-04-26 17:18:07 -0400
committerTom Lane <tgl@sss.pgh.pa.us>2019-04-26 17:18:07 -0400
commitc01eb619a83aed460b9ead50831265f2acde3c57 (patch)
tree9865d796f64893a3a1372a2a0291a5dc15ee7a7c /contrib/btree_gist/sql/date.sql
parent7fcdb5e002145ec95b2bebb4c125751be66c4d1a (diff)
Apply stopgap fix for bug #15672.
Fix DefineIndex so that it doesn't attempt to pass down a to-be-reused index relfilenode to a child index creation, and fix TryReuseIndex to not think that reuse is sensible for a partitioned index. In v11, this fixes a problem where ALTER TABLE on a partitioned table could assign the same relfilenode to several different child indexes, causing very nasty catalog corruption --- in fact, attempting to DROP the partitioned table then leads not only to a database crash, but to inability to restart because the same crash will recur during WAL replay. Either of these two changes would be enough to prevent the failure, but since neither action could possibly be sane, let's put in both changes for future-proofing. In HEAD, no such bug manifests, but that's just an accidental consequence of having changed the pg_class representation of partitioned indexes to have relfilenode = 0. Both of these changes still seem like smart future-proofing. This is only a stop-gap because the code for ALTER TABLE on a partitioned table with a no-op type change still leaves a great deal to be desired. As the added regression tests show, it gets things wrong for comments on child indexes/constraints, and it is regenerating child indexes it doesn't have to. However, fixing those problems will take more work which may not get back-patched into v11. We need a fix for the corruption problem now. Per bug #15672 from Jianing Yang. Patch by me, regression test cases based on work by Amit Langote, who also did a lot of the investigative work. Discussion: https://postgr.es/m/15672-b9fa7db32698269f@postgresql.org
Diffstat (limited to 'contrib/btree_gist/sql/date.sql')
0 files changed, 0 insertions, 0 deletions