mirror of
https://github.com/postgres/postgres.git
synced 2025-12-21 05:21:08 +03:00
Teach predtest.c about CHECK clauses to fix partitioning bugs.
In a CHECK clause, a null result means true, whereas in a WHERE clause it means false. predtest.c provided different functions depending on which set of semantics applied to the predicate being proved, but had no option to control what a null meant in the clauses provided as axioms. Add one. Use that in the partitioning code when figuring out whether the validation scan on a new partition can be skipped. Rip out the old logic that attempted (not very successfully) to compensate for the absence of the necessary support in predtest.c. Ashutosh Bapat and Robert Haas, reviewed by Amit Langote and incorporating feedback from Tom Lane. Discussion: http://postgr.es/m/CAFjFpReT_kq_uwU_B8aWDxR7jNGE=P0iELycdq5oupi=xSQTOw@mail.gmail.com
This commit is contained in:
@@ -17,9 +17,9 @@
|
||||
#include "nodes/primnodes.h"
|
||||
|
||||
|
||||
extern bool predicate_implied_by(List *predicate_list,
|
||||
List *restrictinfo_list);
|
||||
extern bool predicate_refuted_by(List *predicate_list,
|
||||
List *restrictinfo_list);
|
||||
extern bool predicate_implied_by(List *predicate_list, List *clause_list,
|
||||
bool clause_is_check);
|
||||
extern bool predicate_refuted_by(List *predicate_list, List *clause_list,
|
||||
bool clause_is_check);
|
||||
|
||||
#endif /* PREDTEST_H */
|
||||
|
||||
Reference in New Issue
Block a user