Andres Freund <and...@anarazel.de> writes: > If we moved attcompression to all the other bool/char fields, we'd avoid > that size increase, as there's an existing 2 byte hole.
+1. Looks to me like its existing placement was according to the good old "add new things at the end" anti-pattern. It certainly isn't related to the adjacent fields. Putting it just after attalign seems like a reasonably sane choice from the standpoint of grouping things affecting physical storage; and as you say, that wins from the standpoint of using up alignment padding rather than adding more. Personally I'd think the most consistent order in that area would be attbyval, attalign, attstorage, attcompression; but perhaps it's too late to swap the order of attstorage and attalign. regards, tom lane