From 389af951552ff2209eae3e62fa147fef12329d4f Mon Sep 17 00:00:00 2001 From: Tom Lane Date: Fri, 25 Feb 2011 18:56:23 -0500 Subject: Support data-modifying commands (INSERT/UPDATE/DELETE) in WITH. This patch implements data-modifying WITH queries according to the semantics that the updates all happen with the same command counter value, and in an unspecified order. Therefore one WITH clause can't see the effects of another, nor can the outer query see the effects other than through the RETURNING values. And attempts to do conflicting updates will have unpredictable results. We'll need to document all that. This commit just fixes the code; documentation updates are waiting on author. Marko Tiikkaja and Hitoshi Harada --- src/backend/parser/parse_clause.c | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) (limited to 'src/backend/parser/parse_clause.c') diff --git a/src/backend/parser/parse_clause.c b/src/backend/parser/parse_clause.c index d250e0c8598..4c5a6fe0b01 100644 --- a/src/backend/parser/parse_clause.c +++ b/src/backend/parser/parse_clause.c @@ -458,7 +458,7 @@ transformCTEReference(ParseState *pstate, RangeVar *r, { RangeTblEntry *rte; - rte = addRangeTableEntryForCTE(pstate, cte, levelsup, r->alias, true); + rte = addRangeTableEntryForCTE(pstate, cte, levelsup, r, true); return rte; } -- cgit v1.2.3