CheckNNConstraintFetch: Fill all of ConstrCheck in a single pass
authorÁlvaro Herrera <[email protected]>
Wed, 29 Oct 2025 10:41:39 +0000 (11:41 +0100)
committerÁlvaro Herrera <[email protected]>
Wed, 29 Oct 2025 10:41:39 +0000 (11:41 +0100)
commit94f95d91b025cb6752b4118bb0b30851e3d64df9
tree3615c5c6faffab831d0a3d543dc487527cf514c2
parenta13833c35f9e07fe978bf6fad984d6f5f25f59cd
CheckNNConstraintFetch: Fill all of ConstrCheck in a single pass

Previously, we'd fill all fields except ccbin, and only later obtain and
detoast ccbin, with hypothetical failures being possible.  If ccbin is
null (rare catalog corruption I have never witnessed) or its a corrupted
toast entry, we leak a tiny bit of memory in CacheMemoryContext from
having strdup'd the constraint name.  Repair these by only attempting to
fill the struct once ccbin has been detoasted.

Author: Ranier Vilela <[email protected]>
Discussion: https://postgr.es/m/CAEudQAr=i3_Z4GvmediX900+sSySTeMkvuytYShhQqEwoGyvhA@mail.gmail.com
src/backend/utils/cache/relcache.c