mirror of
				https://github.com/postgres/postgres.git
				synced 2025-10-25 13:17:41 +03:00 
			
		
		
		
	Fix handling of NULL constraint conditions: per SQL92 spec, a NULL result
from a constraint condition does not violate the constraint (cf. discussion on pghackers 12/9/99). Implemented by adding a parameter to ExecQual, specifying whether to return TRUE or FALSE when the qual result is really NULL in three-valued boolean logic. Currently, ExecRelCheck is the only caller that asks for TRUE, but if we find any other places that have the wrong response to NULL, it'll be easy to fix them.
This commit is contained in:
		| @@ -27,7 +27,7 @@ | ||||
|  *				   SeqScan (emp.all) | ||||
|  * | ||||
|  * IDENTIFICATION | ||||
|  *	  $Header: /cvsroot/pgsql/src/backend/executor/nodeResult.c,v 1.11 1999/05/25 16:08:46 momjian Exp $ | ||||
|  *	  $Header: /cvsroot/pgsql/src/backend/executor/nodeResult.c,v 1.12 2000/01/19 23:54:55 tgl Exp $ | ||||
|  * | ||||
|  *------------------------------------------------------------------------- | ||||
|  */ | ||||
| @@ -79,7 +79,9 @@ ExecResult(Result *node) | ||||
| 	 */ | ||||
| 	if (resstate->rs_checkqual) | ||||
| 	{ | ||||
| 		bool		qualResult = ExecQual((List *) node->resconstantqual, econtext); | ||||
| 		bool		qualResult = ExecQual((List *) node->resconstantqual, | ||||
| 										  econtext, | ||||
| 										  false); | ||||
|  | ||||
| 		resstate->rs_checkqual = false; | ||||
| 		if (qualResult == false) | ||||
|   | ||||
		Reference in New Issue
	
	Block a user