BTW, with respect to this bit in 0001: @@ -1795,6 +1847,15 @@ nulltestsel(PlannerInfo *root, NullTestType nulltesttype, Node *arg, return (Selectivity) 0; /* keep compiler quiet */ } } + else if (vardata.var && IsA(vardata.var, Var) && + ((Var *) vardata.var)->varattno == SelfItemPointerAttributeNumber) + { + /* + * There are no stats for system columns, but we know CTID is never + * NULL. + */ + selec = (nulltesttype == IS_NULL) ? 0.0 : 1.0; + } else { /*
I'm not entirely sure why you're bothering; surely nulltestsel is unrelated to what this patch is about? And would anybody really write "WHERE ctid IS NULL"? However, if we do think it's worth adding code to cover this case, I wouldn't make it specific to CTID. *All* system columns can be assumed not null, see heap_getsysattr(). regards, tom lane