mirror of
				https://github.com/postgres/postgres.git
				synced 2025-10-25 13:17:41 +03:00 
			
		
		
		
	Teach push_nots() how to negate a ScalarArrayOpExpr. In passing, save
a palloc or two in the OpExpr case.
This commit is contained in:
		| @@ -25,7 +25,7 @@ | |||||||
|  * |  * | ||||||
|  * |  * | ||||||
|  * IDENTIFICATION |  * IDENTIFICATION | ||||||
|  *	  $PostgreSQL: pgsql/src/backend/optimizer/prep/prepqual.c,v 1.52 2005/11/22 18:17:14 momjian Exp $ |  *	  $PostgreSQL: pgsql/src/backend/optimizer/prep/prepqual.c,v 1.53 2005/11/26 18:07:40 tgl Exp $ | ||||||
|  * |  * | ||||||
|  *------------------------------------------------------------------------- |  *------------------------------------------------------------------------- | ||||||
|  */ |  */ | ||||||
| @@ -212,11 +212,40 @@ push_nots(Expr *qual) | |||||||
| 		Oid			negator = get_negator(opexpr->opno); | 		Oid			negator = get_negator(opexpr->opno); | ||||||
|  |  | ||||||
| 		if (negator) | 		if (negator) | ||||||
| 			return make_opclause(negator, | 		{ | ||||||
| 								 opexpr->opresulttype, | 			OpExpr *newopexpr = makeNode(OpExpr); | ||||||
| 								 opexpr->opretset, |  | ||||||
| 								 (Expr *) get_leftop(qual), | 			newopexpr->opno = negator; | ||||||
| 								 (Expr *) get_rightop(qual)); | 			newopexpr->opfuncid = InvalidOid; | ||||||
|  | 			newopexpr->opresulttype = opexpr->opresulttype; | ||||||
|  | 			newopexpr->opretset = opexpr->opretset; | ||||||
|  | 			newopexpr->args = opexpr->args; | ||||||
|  | 			return (Expr *) newopexpr; | ||||||
|  | 		} | ||||||
|  | 		else | ||||||
|  | 			return make_notclause(qual); | ||||||
|  | 	} | ||||||
|  | 	else if (qual && IsA(qual, ScalarArrayOpExpr)) | ||||||
|  | 	{ | ||||||
|  | 		/* | ||||||
|  | 		 * Negate a ScalarArrayOpExpr if there is a negator for its operator; | ||||||
|  | 		 * for example x = ANY (list) becomes x <> ALL (list). | ||||||
|  | 		 * Otherwise, retain the clause as it is (the NOT can't be pushed down | ||||||
|  | 		 * any farther). | ||||||
|  | 		 */ | ||||||
|  | 		ScalarArrayOpExpr *saopexpr = (ScalarArrayOpExpr *) qual; | ||||||
|  | 		Oid			negator = get_negator(saopexpr->opno); | ||||||
|  |  | ||||||
|  | 		if (negator) | ||||||
|  | 		{ | ||||||
|  | 			ScalarArrayOpExpr *newopexpr = makeNode(ScalarArrayOpExpr); | ||||||
|  |  | ||||||
|  | 			newopexpr->opno = negator; | ||||||
|  | 			newopexpr->opfuncid = InvalidOid; | ||||||
|  | 			newopexpr->useOr = !saopexpr->useOr; | ||||||
|  | 			newopexpr->args = saopexpr->args; | ||||||
|  | 			return (Expr *) newopexpr; | ||||||
|  | 		} | ||||||
| 		else | 		else | ||||||
| 			return make_notclause(qual); | 			return make_notclause(qual); | ||||||
| 	} | 	} | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user