Commit 763ff8ae authored by Bruce Momjian's avatar Bruce Momjian

Remove Query->qry_aggs and qry_numaggs and replace with Query->hasAggs.

Pass List* of Aggregs into executor, and create needed array there.
No longer need to double-processs Aggregs with second copy in Query.

Fix crash when doing:

	select sum(x+1) from test where 1 > 0;
parent f22d8e66
...@@ -105,6 +105,7 @@ ExecAgg(Agg *node) ...@@ -105,6 +105,7 @@ ExecAgg(Agg *node)
ProjectionInfo *projInfo; ProjectionInfo *projInfo;
TupleTableSlot *resultSlot; TupleTableSlot *resultSlot;
HeapTuple oneTuple; HeapTuple oneTuple;
List *alist;
char *nulls; char *nulls;
bool isDone; bool isDone;
bool isNull = FALSE, bool isNull = FALSE,
...@@ -121,8 +122,17 @@ ExecAgg(Agg *node) ...@@ -121,8 +122,17 @@ ExecAgg(Agg *node)
estate = node->plan.state; estate = node->plan.state;
econtext = aggstate->csstate.cstate.cs_ExprContext; econtext = aggstate->csstate.cstate.cs_ExprContext;
aggregates = node->aggs; nagg = length(node->aggs);
nagg = node->numAgg;
aggregates = (Aggreg **)palloc(sizeof(Aggreg *) * nagg);
/* take List* and make it an array that can be quickly indexed */
alist = node->aggs;
for (i = 0; i < nagg; i++)
{
aggregates[i] = lfirst(alist);
alist = lnext(alist);
}
value1 = node->aggstate->csstate.cstate.cs_ExprContext->ecxt_values; value1 = node->aggstate->csstate.cstate.cs_ExprContext->ecxt_values;
nulls = node->aggstate->csstate.cstate.cs_ExprContext->ecxt_nulls; nulls = node->aggstate->csstate.cstate.cs_ExprContext->ecxt_nulls;
...@@ -540,10 +550,10 @@ ExecInitAgg(Agg *node, EState *estate, Plan *parent) ...@@ -540,10 +550,10 @@ ExecInitAgg(Agg *node, EState *estate, Plan *parent)
econtext = aggstate->csstate.cstate.cs_ExprContext; econtext = aggstate->csstate.cstate.cs_ExprContext;
econtext->ecxt_values = econtext->ecxt_values =
(Datum *) palloc(sizeof(Datum) * node->numAgg); (Datum *) palloc(sizeof(Datum) * length(node->aggs));
MemSet(econtext->ecxt_values, 0, sizeof(Datum) * node->numAgg); MemSet(econtext->ecxt_values, 0, sizeof(Datum) * length(node->aggs));
econtext->ecxt_nulls = (char *) palloc(node->numAgg); econtext->ecxt_nulls = (char *) palloc(length(node->aggs));
MemSet(econtext->ecxt_nulls, 0, node->numAgg); MemSet(econtext->ecxt_nulls, 0, length(node->aggs));
/* /*
* initializes child nodes * initializes child nodes
......
...@@ -7,7 +7,7 @@ ...@@ -7,7 +7,7 @@
* *
* *
* IDENTIFICATION * IDENTIFICATION
* $Header: /cvsroot/pgsql/src/backend/nodes/copyfuncs.c,v 1.29 1998/01/11 20:01:53 momjian Exp $ * $Header: /cvsroot/pgsql/src/backend/nodes/copyfuncs.c,v 1.30 1998/01/15 18:59:20 momjian Exp $
* *
*------------------------------------------------------------------------- *-------------------------------------------------------------------------
*/ */
...@@ -493,15 +493,10 @@ static Agg * ...@@ -493,15 +493,10 @@ static Agg *
_copyAgg(Agg *from) _copyAgg(Agg *from)
{ {
Agg *newnode = makeNode(Agg); Agg *newnode = makeNode(Agg);
int i;
CopyPlanFields((Plan *) from, (Plan *) newnode); CopyPlanFields((Plan *) from, (Plan *) newnode);
newnode->numAgg = from->numAgg; Node_Copy(from, newnode, aggs);
newnode->aggs = palloc(sizeof(Aggreg *));
for (i = 0; i < from->numAgg; i++)
newnode->aggs[i] = copyObject(from->aggs[i]);
Node_Copy(from, newnode, aggstate); Node_Copy(from, newnode, aggstate);
return newnode; return newnode;
...@@ -1495,7 +1490,6 @@ static Query * ...@@ -1495,7 +1490,6 @@ static Query *
_copyQuery(Query *from) _copyQuery(Query *from)
{ {
Query *newnode = makeNode(Query); Query *newnode = makeNode(Query);
int i;
newnode->commandType = from->commandType; newnode->commandType = from->commandType;
if (from->utilityStmt && nodeTag(from->utilityStmt) == T_NotifyStmt) if (from->utilityStmt && nodeTag(from->utilityStmt) == T_NotifyStmt)
...@@ -1522,14 +1516,7 @@ _copyQuery(Query *from) ...@@ -1522,14 +1516,7 @@ _copyQuery(Query *from)
Node_Copy(from, newnode, groupClause); Node_Copy(from, newnode, groupClause);
Node_Copy(from, newnode, havingQual); Node_Copy(from, newnode, havingQual);
newnode->qry_numAgg = from->qry_numAgg; newnode->hasAggs = from->hasAggs;
if (from->qry_numAgg > 0)
{
newnode->qry_aggs =
(Aggreg **) palloc(sizeof(Aggreg *) * from->qry_numAgg);
for (i=0; i < from->qry_numAgg; i++)
newnode->qry_aggs[i] = _copyAggreg(from->qry_aggs[i]);
}
if (from->unionClause) if (from->unionClause)
{ {
......
...@@ -7,7 +7,7 @@ ...@@ -7,7 +7,7 @@
* *
* *
* IDENTIFICATION * IDENTIFICATION
* $Header: /cvsroot/pgsql/src/backend/nodes/list.c,v 1.10 1998/01/07 21:03:29 momjian Exp $ * $Header: /cvsroot/pgsql/src/backend/nodes/list.c,v 1.11 1998/01/15 18:59:23 momjian Exp $
* *
* NOTES * NOTES
* XXX a few of the following functions are duplicated to handle * XXX a few of the following functions are duplicated to handle
...@@ -89,6 +89,48 @@ lappendi(List *list, int datum) ...@@ -89,6 +89,48 @@ lappendi(List *list, int datum)
return nconc(list, lconsi(datum, NIL)); return nconc(list, lconsi(datum, NIL));
} }
List *
nconc(List *l1, List *l2)
{
List *temp;
if (l1 == NIL)
return l2;
if (l2 == NIL)
return l1;
if (l1 == l2)
elog(ERROR, "tryout to nconc a list to itself");
for (temp = l1; lnext(temp) != NULL; temp = lnext(temp))
;
lnext(temp) = l2;
return (l1); /* list1 is now list1[]list2 */
}
List *
nreverse(List *list)
{
List *rlist = NIL;
List *p = NIL;
if (list == NULL)
return (NIL);
if (length(list) == 1)
return (list);
for (p = list; p != NULL; p = lnext(p))
{
rlist = lcons(lfirst(p), rlist);
}
lfirst(list) = lfirst(rlist);
lnext(list) = lnext(rlist);
return (list);
}
Value * Value *
makeInteger(long i) makeInteger(long i)
{ {
...@@ -227,48 +269,6 @@ intAppend(List *l1, List *l2) ...@@ -227,48 +269,6 @@ intAppend(List *l1, List *l2)
return newlist; return newlist;
} }
List *
nconc(List *l1, List *l2)
{
List *temp;
if (l1 == NIL)
return l2;
if (l2 == NIL)
return l1;
if (l1 == l2)
elog(ERROR, "tryout to nconc a list to itself");
for (temp = l1; lnext(temp) != NULL; temp = lnext(temp))
;
lnext(temp) = l2;
return (l1); /* list1 is now list1[]list2 */
}
List *
nreverse(List *list)
{
List *rlist = NIL;
List *p = NIL;
if (list == NULL)
return (NIL);
if (length(list) == 1)
return (list);
for (p = list; p != NULL; p = lnext(p))
{
rlist = lcons(lfirst(p), rlist);
}
lfirst(list) = lfirst(rlist);
lnext(list) = lnext(rlist);
return (list);
}
/* /*
* same * same
* *
......
...@@ -7,7 +7,7 @@ ...@@ -7,7 +7,7 @@
* *
* *
* IDENTIFICATION * IDENTIFICATION
* $Header: /cvsroot/pgsql/src/backend/nodes/outfuncs.c,v 1.20 1998/01/07 15:32:25 momjian Exp $ * $Header: /cvsroot/pgsql/src/backend/nodes/outfuncs.c,v 1.21 1998/01/15 18:59:26 momjian Exp $
* *
* NOTES * NOTES
* Every (plan) node in POSTGRES has an associated "out" routine which * Every (plan) node in POSTGRES has an associated "out" routine which
...@@ -163,7 +163,6 @@ static void ...@@ -163,7 +163,6 @@ static void
_outQuery(StringInfo str, Query *node) _outQuery(StringInfo str, Query *node)
{ {
char buf[500]; char buf[500];
int i;
appendStringInfo(str, "QUERY"); appendStringInfo(str, "QUERY");
...@@ -229,12 +228,8 @@ _outQuery(StringInfo str, Query *node) ...@@ -229,12 +228,8 @@ _outQuery(StringInfo str, Query *node)
_outNode(str, node->groupClause); _outNode(str, node->groupClause);
appendStringInfo(str, " :havingQual "); appendStringInfo(str, " :havingQual ");
_outNode(str, node->havingQual); _outNode(str, node->havingQual);
appendStringInfo(str, " :qry_numAgg "); appendStringInfo(str, " :hasAggs ");
sprintf(buf, " %d ", node->qry_numAgg); appendStringInfo(str, (node->hasAggs ? "true" : "false"));
appendStringInfo(str, buf);
appendStringInfo(str, " :qry_aggs ");
for (i=0; i < node->qry_numAgg; i++)
_outNode(str, node->qry_aggs[i]);
appendStringInfo(str, " :unionClause "); appendStringInfo(str, " :unionClause ");
_outNode(str, node->unionClause); _outNode(str, node->unionClause);
} }
...@@ -505,14 +500,12 @@ _outSort(StringInfo str, Sort *node) ...@@ -505,14 +500,12 @@ _outSort(StringInfo str, Sort *node)
static void static void
_outAgg(StringInfo str, Agg *node) _outAgg(StringInfo str, Agg *node)
{ {
char buf[500];
appendStringInfo(str, "AGG"); appendStringInfo(str, "AGG");
_outPlanInfo(str, (Plan *) node); _outPlanInfo(str, (Plan *) node);
/* the actual Agg fields */ appendStringInfo(str, " :aggs ");
sprintf(buf, " :numagg %d ", node->numAgg); _outNode(str, node->aggs);
appendStringInfo(str, buf);
} }
static void static void
......
...@@ -7,7 +7,7 @@ ...@@ -7,7 +7,7 @@
* *
* *
* IDENTIFICATION * IDENTIFICATION
* $Header: /cvsroot/pgsql/src/backend/nodes/readfuncs.c,v 1.17 1998/01/07 21:03:37 momjian Exp $ * $Header: /cvsroot/pgsql/src/backend/nodes/readfuncs.c,v 1.18 1998/01/15 18:59:31 momjian Exp $
* *
* NOTES * NOTES
* Most of the read functions for plan nodes are tested. (In fact, they * Most of the read functions for plan nodes are tested. (In fact, they
...@@ -76,7 +76,6 @@ _readQuery() ...@@ -76,7 +76,6 @@ _readQuery()
Query *local_node; Query *local_node;
char *token; char *token;
int length; int length;
int i;
local_node = makeNode(Query); local_node = makeNode(Query);
...@@ -153,19 +152,9 @@ _readQuery() ...@@ -153,19 +152,9 @@ _readQuery()
token = lsptok(NULL, &length); /* skip :havingQual */ token = lsptok(NULL, &length); /* skip :havingQual */
local_node->havingQual = nodeRead(true); local_node->havingQual = nodeRead(true);
token = lsptok(NULL, &length); /* skip the :qry_numAgg */ token = lsptok(NULL, &length); /* skip the :hasAggs */
token = lsptok(NULL, &length); /* get qry_numAgg */ token = lsptok(NULL, &length); /* get hasAggs */
local_node->qry_numAgg = atoi(token); local_node->hasAggs = (token[0] == 't') ? true : false;
token = lsptok(NULL, &length); /* skip the :qry_Aggs */
if (local_node->qry_numAgg == 0)
local_node->qry_aggs = NULL;
else
{
local_node->qry_aggs = palloc(sizeof(Aggreg *) * local_node->qry_numAgg);
for (i=0; i < local_node->qry_numAgg; i++)
local_node->qry_aggs[i] = nodeRead(true);
}
token = lsptok(NULL, &length); /* skip :unionClause */ token = lsptok(NULL, &length); /* skip :unionClause */
local_node->unionClause = nodeRead(true); local_node->unionClause = nodeRead(true);
...@@ -618,9 +607,8 @@ _readAgg() ...@@ -618,9 +607,8 @@ _readAgg()
local_node = makeNode(Agg); local_node = makeNode(Agg);
_getPlan((Plan *) local_node); _getPlan((Plan *) local_node);
token = lsptok(NULL, &length); /* eat :numagg */ token = lsptok(NULL, &length); /* eat :agg */
token = lsptok(NULL, &length); /* get numagg */ local_node->aggs = nodeRead(true); /* now read it */
local_node->numAgg = atoi(token);
return (local_node); return (local_node);
} }
......
...@@ -7,7 +7,7 @@ ...@@ -7,7 +7,7 @@
* *
* *
* IDENTIFICATION * IDENTIFICATION
* $Header: /cvsroot/pgsql/src/backend/optimizer/plan/createplan.c,v 1.22 1998/01/07 21:04:01 momjian Exp $ * $Header: /cvsroot/pgsql/src/backend/optimizer/plan/createplan.c,v 1.23 1998/01/15 18:59:37 momjian Exp $
* *
*------------------------------------------------------------------------- *-------------------------------------------------------------------------
*/ */
...@@ -1106,7 +1106,7 @@ make_material(List *tlist, ...@@ -1106,7 +1106,7 @@ make_material(List *tlist,
} }
Agg * Agg *
make_agg(List *tlist, int nagg, Aggreg **aggs, Plan *lefttree) make_agg(List *tlist, Plan *lefttree)
{ {
Agg *node = makeNode(Agg); Agg *node = makeNode(Agg);
...@@ -1116,8 +1116,7 @@ make_agg(List *tlist, int nagg, Aggreg **aggs, Plan *lefttree) ...@@ -1116,8 +1116,7 @@ make_agg(List *tlist, int nagg, Aggreg **aggs, Plan *lefttree)
node->plan.targetlist = tlist; node->plan.targetlist = tlist;
node->plan.lefttree = lefttree; node->plan.lefttree = lefttree;
node->plan.righttree = (Plan *) NULL; node->plan.righttree = (Plan *) NULL;
node->numAgg = nagg; node->aggs = NIL;
node->aggs = aggs;
return (node); return (node);
} }
......
...@@ -7,7 +7,7 @@ ...@@ -7,7 +7,7 @@
* *
* *
* IDENTIFICATION * IDENTIFICATION
* $Header: /cvsroot/pgsql/src/backend/optimizer/plan/planmain.c,v 1.15 1998/01/07 21:04:04 momjian Exp $ * $Header: /cvsroot/pgsql/src/backend/optimizer/plan/planmain.c,v 1.16 1998/01/15 18:59:44 momjian Exp $
* *
*------------------------------------------------------------------------- *-------------------------------------------------------------------------
*/ */
...@@ -71,7 +71,7 @@ query_planner(Query *root, ...@@ -71,7 +71,7 @@ query_planner(Query *root,
List *constant_qual = NIL; List *constant_qual = NIL;
List *var_only_tlist = NIL; List *var_only_tlist = NIL;
List *level_tlist = NIL; List *level_tlist = NIL;
Plan *subplan = (Plan *) NULL; Plan *subplan = NULL;
/* /*
* A command without a target list or qualification is an error, * A command without a target list or qualification is an error,
...@@ -174,20 +174,19 @@ query_planner(Query *root, ...@@ -174,20 +174,19 @@ query_planner(Query *root,
*/ */
if (constant_qual) if (constant_qual)
{ {
Plan *plan; subplan = (Plan *)make_result((!root->hasAggs && !root->groupClause)
? tlist : subplan->targetlist,
plan = (Plan *) make_result(tlist,
(Node *) constant_qual, (Node *) constant_qual,
subplan); subplan);
/* /*
* Change all varno's of the Result's node target list. * Change all varno's of the Result's node target list.
*/ */
set_result_tlist_references((Result *) plan); if (!root->hasAggs && !root->groupClause)
set_tlist_references(subplan);
return (plan); return subplan;
} }
/* /*
* fix up the flattened target list of the plan root node so that * fix up the flattened target list of the plan root node so that
* expressions are evaluated. this forces expression evaluations that * expressions are evaluated. this forces expression evaluations that
...@@ -201,10 +200,12 @@ query_planner(Query *root, ...@@ -201,10 +200,12 @@ query_planner(Query *root,
* aggregates fixing only other entries (i.e. - GroupBy-ed and so * aggregates fixing only other entries (i.e. - GroupBy-ed and so
* fixed by make_groupPlan). - vadim 04/05/97 * fixed by make_groupPlan). - vadim 04/05/97
*/ */
if (root->groupClause == NULL && root->qry_aggs == NULL) else
{ {
if (!root->hasAggs && !root->groupClause)
subplan->targetlist = flatten_tlist_vars(tlist, subplan->targetlist = flatten_tlist_vars(tlist,
subplan->targetlist); subplan->targetlist);
return subplan;
} }
#ifdef NOT_USED #ifdef NOT_USED
...@@ -215,7 +216,6 @@ query_planner(Query *root, ...@@ -215,7 +216,6 @@ query_planner(Query *root,
subplan->targetlist = generate_fjoin(subplan->targetlist); subplan->targetlist = generate_fjoin(subplan->targetlist);
#endif #endif
return (subplan);
} }
/* /*
......
...@@ -7,7 +7,7 @@ ...@@ -7,7 +7,7 @@
* *
* *
* IDENTIFICATION * IDENTIFICATION
* $Header: /cvsroot/pgsql/src/backend/optimizer/plan/planner.c,v 1.20 1998/01/07 21:04:05 momjian Exp $ * $Header: /cvsroot/pgsql/src/backend/optimizer/plan/planner.c,v 1.21 1998/01/15 18:59:48 momjian Exp $
* *
*------------------------------------------------------------------------- *-------------------------------------------------------------------------
*/ */
...@@ -117,7 +117,7 @@ planner(Query *parse) ...@@ -117,7 +117,7 @@ planner(Query *parse)
* If we have a GROUP BY clause, insert a group node (with the * If we have a GROUP BY clause, insert a group node (with the
* appropriate sort node.) * appropriate sort node.)
*/ */
if (parse->groupClause != NULL) if (parse->groupClause)
{ {
bool tuplePerGroup; bool tuplePerGroup;
...@@ -127,7 +127,7 @@ planner(Query *parse) ...@@ -127,7 +127,7 @@ planner(Query *parse)
* present. Otherwise, need every tuple from the group to do the * present. Otherwise, need every tuple from the group to do the
* aggregation.) * aggregation.)
*/ */
tuplePerGroup = (parse->qry_aggs) ? TRUE : FALSE; tuplePerGroup = parse->hasAggs;
result_plan = result_plan =
make_groupPlan( &tlist, make_groupPlan( &tlist,
...@@ -140,22 +140,16 @@ planner(Query *parse) ...@@ -140,22 +140,16 @@ planner(Query *parse)
/* /*
* If aggregate is present, insert the agg node * If aggregate is present, insert the agg node
*/ */
if (parse->qry_aggs) if (parse->hasAggs)
{ {
result_plan = (Plan *)make_agg(tlist, result_plan = (Plan *)make_agg(tlist, result_plan);
parse->qry_numAgg,
parse->qry_aggs,
result_plan);
/* /*
* set the varno/attno entries to the appropriate references to * set the varno/attno entries to the appropriate references to
* the result tuple of the subplans. (We need to set those in the * the result tuple of the subplans.
* array of aggreg's in the Agg node also. Even though they're
* pointers, after a few dozen's of copying, they're not the same
* as those in the target list.)
*/ */
((Agg *)result_plan)->aggs =
set_agg_tlist_references((Agg *)result_plan); set_agg_tlist_references((Agg *)result_plan);
set_agg_agglist_references((Agg *)result_plan);
} }
/* /*
......
...@@ -7,7 +7,7 @@ ...@@ -7,7 +7,7 @@
* *
* *
* IDENTIFICATION * IDENTIFICATION
* $Header: /cvsroot/pgsql/src/backend/optimizer/plan/setrefs.c,v 1.14 1998/01/14 19:55:53 momjian Exp $ * $Header: /cvsroot/pgsql/src/backend/optimizer/plan/setrefs.c,v 1.15 1998/01/15 18:59:50 momjian Exp $
* *
*------------------------------------------------------------------------- *-------------------------------------------------------------------------
*/ */
...@@ -44,7 +44,7 @@ static Var *replace_joinvar_refs(Var *var, List *outer_tlist, List *inner_tlist) ...@@ -44,7 +44,7 @@ static Var *replace_joinvar_refs(Var *var, List *outer_tlist, List *inner_tlist)
static List *tlist_temp_references(Oid tempid, List *tlist); static List *tlist_temp_references(Oid tempid, List *tlist);
static void replace_result_clause(Node *clause, List *subplanTargetList); static void replace_result_clause(Node *clause, List *subplanTargetList);
static bool OperandIsInner(Node *opnd, int inner_relid); static bool OperandIsInner(Node *opnd, int inner_relid);
static void replace_agg_clause(Node *expr, List *targetlist); static List *replace_agg_clause(Node *expr, List *targetlist);
static Node *del_agg_clause(Node *clause); static Node *del_agg_clause(Node *clause);
/***************************************************************************** /*****************************************************************************
...@@ -536,13 +536,9 @@ set_result_tlist_references(Result *resultNode) ...@@ -536,13 +536,9 @@ set_result_tlist_references(Result *resultNode)
*/ */
subplan = ((Plan *) resultNode)->lefttree; subplan = ((Plan *) resultNode)->lefttree;
if (subplan != NULL) if (subplan != NULL)
{
subplanTargetList = subplan->targetlist; subplanTargetList = subplan->targetlist;
}
else else
{
subplanTargetList = NIL; subplanTargetList = NIL;
}
/* /*
* now for traverse all the entris of the target list. These should be * now for traverse all the entris of the target list. These should be
...@@ -695,13 +691,16 @@ OperandIsInner(Node *opnd, int inner_relid) ...@@ -695,13 +691,16 @@ OperandIsInner(Node *opnd, int inner_relid)
* changes the target list of an Agg node so that it points to * changes the target list of an Agg node so that it points to
* the tuples returned by its left tree subplan. * the tuples returned by its left tree subplan.
* *
* We now also generate a linked list of Aggreg pointers for Agg.
*
*/ */
void List *
set_agg_tlist_references(Agg *aggNode) set_agg_tlist_references(Agg *aggNode)
{ {
List *aggTargetList; List *aggTargetList;
List *subplanTargetList; List *subplanTargetList;
List *tl; List *tl;
List *aggreg_list = NIL;
aggTargetList = aggNode->plan.targetlist; aggTargetList = aggNode->plan.targetlist;
subplanTargetList = aggNode->plan.lefttree->targetlist; subplanTargetList = aggNode->plan.lefttree->targetlist;
...@@ -710,30 +709,18 @@ set_agg_tlist_references(Agg *aggNode) ...@@ -710,30 +709,18 @@ set_agg_tlist_references(Agg *aggNode)
{ {
TargetEntry *tle = lfirst(tl); TargetEntry *tle = lfirst(tl);
replace_agg_clause(tle->expr, subplanTargetList); aggreg_list = nconc(
replace_agg_clause(tle->expr, subplanTargetList),aggreg_list);
} }
return aggreg_list;
} }
void static List *
set_agg_agglist_references(Agg *aggNode)
{
List *subplanTargetList;
Aggreg **aggs;
int i;
aggs = aggNode->aggs;
subplanTargetList = aggNode->plan.lefttree->targetlist;
for (i = 0; i < aggNode->numAgg; i++)
{
replace_agg_clause(aggs[i]->target, subplanTargetList);
}
}
static void
replace_agg_clause(Node *clause, List *subplanTargetList) replace_agg_clause(Node *clause, List *subplanTargetList)
{ {
List *t; List *t;
List *agg_list = NIL;
if (IsA(clause, Var)) if (IsA(clause, Var))
{ {
TargetEntry *subplanVar; TargetEntry *subplanVar;
...@@ -748,22 +735,26 @@ replace_agg_clause(Node *clause, List *subplanTargetList) ...@@ -748,22 +735,26 @@ replace_agg_clause(Node *clause, List *subplanTargetList)
* *
*/ */
((Var *) clause)->varattno = subplanVar->resdom->resno; ((Var *) clause)->varattno = subplanVar->resdom->resno;
return NIL;
} }
else if (is_funcclause(clause)) else if (is_funcclause(clause))
{ {
/* /*
* This is a function. Recursively call this routine for its * This is a function. Recursively call this routine for its
* arguments... * arguments...
*/ */
foreach(t, ((Expr *) clause)->args) foreach(t, ((Expr *) clause)->args)
{ {
replace_agg_clause(lfirst(t), subplanTargetList); agg_list = nconc(agg_list,
replace_agg_clause(lfirst(t), subplanTargetList));
} }
return agg_list;
} }
else if (IsA(clause, Aggreg)) else if (IsA(clause, Aggreg))
{ {
replace_agg_clause(((Aggreg *) clause)->target, subplanTargetList); return lcons(clause,
replace_agg_clause(((Aggreg *) clause)->target, subplanTargetList));
} }
else if (IsA(clause, ArrayRef)) else if (IsA(clause, ArrayRef))
{ {
...@@ -775,14 +766,20 @@ replace_agg_clause(Node *clause, List *subplanTargetList) ...@@ -775,14 +766,20 @@ replace_agg_clause(Node *clause, List *subplanTargetList)
*/ */
foreach(t, aref->refupperindexpr) foreach(t, aref->refupperindexpr)
{ {
replace_agg_clause(lfirst(t), subplanTargetList); agg_list = nconc(agg_list,
replace_agg_clause(lfirst(t), subplanTargetList));
} }
foreach(t, aref->reflowerindexpr) foreach(t, aref->reflowerindexpr)
{ {
replace_agg_clause(lfirst(t), subplanTargetList); agg_list = nconc(agg_list,
replace_agg_clause(lfirst(t), subplanTargetList));
} }
replace_agg_clause(aref->refexpr, subplanTargetList); agg_list = nconc(agg_list,
replace_agg_clause(aref->refassgnexpr, subplanTargetList); replace_agg_clause(aref->refexpr, subplanTargetList));
agg_list = nconc(agg_list,
replace_agg_clause(aref->refassgnexpr, subplanTargetList));
return agg_list;
} }
else if (is_opclause(clause)) else if (is_opclause(clause))
{ {
...@@ -794,13 +791,18 @@ replace_agg_clause(Node *clause, List *subplanTargetList) ...@@ -794,13 +791,18 @@ replace_agg_clause(Node *clause, List *subplanTargetList)
Node *right = (Node *) get_rightop((Expr *) clause); Node *right = (Node *) get_rightop((Expr *) clause);
if (left != (Node *) NULL) if (left != (Node *) NULL)
replace_agg_clause(left, subplanTargetList); agg_list = nconc(agg_list,
replace_agg_clause(left, subplanTargetList));
if (right != (Node *) NULL) if (right != (Node *) NULL)
replace_agg_clause(right, subplanTargetList); agg_list = nconc(agg_list,
replace_agg_clause(right, subplanTargetList));
return agg_list;
} }
else if (IsA(clause, Param) ||IsA(clause, Const)) else if (IsA(clause, Param) ||IsA(clause, Const))
{ {
/* do nothing! */ /* do nothing! */
return NIL;
} }
else else
{ {
...@@ -809,8 +811,8 @@ replace_agg_clause(Node *clause, List *subplanTargetList) ...@@ -809,8 +811,8 @@ replace_agg_clause(Node *clause, List *subplanTargetList)
* Ooops! we can not handle that! * Ooops! we can not handle that!
*/ */
elog(ERROR, "replace_agg_clause: Can not handle this tlist!\n"); elog(ERROR, "replace_agg_clause: Can not handle this tlist!\n");
return NIL;
} }
} }
/* /*
......
...@@ -7,7 +7,7 @@ ...@@ -7,7 +7,7 @@
* *
* *
* IDENTIFICATION * IDENTIFICATION
* $Header: /cvsroot/pgsql/src/backend/optimizer/prep/prepunion.c,v 1.17 1997/12/29 04:31:23 momjian Exp $ * $Header: /cvsroot/pgsql/src/backend/optimizer/prep/prepunion.c,v 1.18 1998/01/15 18:59:53 momjian Exp $
* *
*------------------------------------------------------------------------- *-------------------------------------------------------------------------
*/ */
...@@ -185,8 +185,7 @@ plan_union_queries(Query *parse) ...@@ -185,8 +185,7 @@ plan_union_queries(Query *parse)
parse->uniqueFlag = NULL; parse->uniqueFlag = NULL;
parse->havingQual = NULL; parse->havingQual = NULL;
parse->qry_numAgg = 0; parse->hasAggs = false;
parse->qry_aggs = NULL;
return (make_append(union_plans, return (make_append(union_plans,
union_rts, union_rts,
...@@ -267,11 +266,9 @@ plan_inherit_query(List *relids, ...@@ -267,11 +266,9 @@ plan_inherit_query(List *relids,
new_root->uniqueFlag = NULL; new_root->uniqueFlag = NULL;
new_root->sortClause = NULL; new_root->sortClause = NULL;
new_root->groupClause = NULL; new_root->groupClause = NULL;
if (new_root->qry_numAgg != 0) if (new_root->hasAggs)
{ {
new_root->qry_numAgg = 0; new_root->hasAggs = false;
pfree(new_root->qry_aggs);
new_root->qry_aggs = NULL;
del_agg_tlist_references(new_root->targetList); del_agg_tlist_references(new_root->targetList);
} }
fix_parsetree_attnums(rt_index, fix_parsetree_attnums(rt_index,
......
...@@ -7,7 +7,7 @@ ...@@ -7,7 +7,7 @@
* *
* *
* IDENTIFICATION * IDENTIFICATION
* $Header: /cvsroot/pgsql/src/backend/parser/analyze.c,v 1.64 1998/01/11 03:41:35 momjian Exp $ * $Header: /cvsroot/pgsql/src/backend/parser/analyze.c,v 1.65 1998/01/15 18:59:56 momjian Exp $
* *
*------------------------------------------------------------------------- *-------------------------------------------------------------------------
*/ */
...@@ -219,7 +219,7 @@ transformDeleteStmt(ParseState *pstate, DeleteStmt *stmt) ...@@ -219,7 +219,7 @@ transformDeleteStmt(ParseState *pstate, DeleteStmt *stmt)
qry->resultRelation = refnameRangeTablePosn(pstate->p_rtable, stmt->relname); qry->resultRelation = refnameRangeTablePosn(pstate->p_rtable, stmt->relname);
/* make sure we don't have aggregates in the where clause */ /* make sure we don't have aggregates in the where clause */
if (pstate->p_numAgg > 0) if (pstate->p_hasAggs)
parseCheckAggregates(pstate, qry); parseCheckAggregates(pstate, qry);
return (Query *) qry; return (Query *) qry;
...@@ -334,7 +334,7 @@ transformInsertStmt(ParseState *pstate, InsertStmt *stmt) ...@@ -334,7 +334,7 @@ transformInsertStmt(ParseState *pstate, InsertStmt *stmt)
qry->targetList, qry->targetList,
qry->uniqueFlag); qry->uniqueFlag);
if (pstate->p_numAgg > 0) if (pstate->p_hasAggs)
finalizeAggregates(pstate, qry); finalizeAggregates(pstate, qry);
qry->unionall = stmt->unionall; /* in child, so unionClause may be false */ qry->unionall = stmt->unionall; /* in child, so unionClause may be false */
...@@ -796,8 +796,7 @@ transformRuleStmt(ParseState *pstate, RuleStmt *stmt) ...@@ -796,8 +796,7 @@ transformRuleStmt(ParseState *pstate, RuleStmt *stmt)
pstate->p_last_resno = 1; pstate->p_last_resno = 1;
pstate->p_is_rule = true; /* for expand all */ pstate->p_is_rule = true; /* for expand all */
pstate->p_numAgg = 0; pstate->p_hasAggs = false;
pstate->p_aggs = NULL;
lfirst(actions) = transformStmt(pstate, lfirst(actions)); lfirst(actions) = transformStmt(pstate, lfirst(actions));
actions = lnext(actions); actions = lnext(actions);
...@@ -853,7 +852,7 @@ transformSelectStmt(ParseState *pstate, SelectStmt *stmt) ...@@ -853,7 +852,7 @@ transformSelectStmt(ParseState *pstate, SelectStmt *stmt)
qry->targetList); qry->targetList);
qry->rtable = pstate->p_rtable; qry->rtable = pstate->p_rtable;
if (pstate->p_numAgg > 0) if (pstate->p_hasAggs)
finalizeAggregates(pstate, qry); finalizeAggregates(pstate, qry);
qry->unionall = stmt->unionall; /* in child, so unionClause may be false */ qry->unionall = stmt->unionall; /* in child, so unionClause may be false */
...@@ -890,11 +889,11 @@ transformUpdateStmt(ParseState *pstate, UpdateStmt *stmt) ...@@ -890,11 +889,11 @@ transformUpdateStmt(ParseState *pstate, UpdateStmt *stmt)
qry->rtable = pstate->p_rtable; qry->rtable = pstate->p_rtable;
qry->resultRelation = refnameRangeTablePosn(pstate->p_rtable, stmt->relname); qry->resultRelation = refnameRangeTablePosn(pstate->p_rtable, stmt->relname);
if (pstate->p_numAgg > 0) if (pstate->p_hasAggs)
finalizeAggregates(pstate, qry); finalizeAggregates(pstate, qry);
/* make sure we don't have aggregates in the where clause */ /* make sure we don't have aggregates in the where clause */
if (pstate->p_numAgg > 0) if (pstate->p_hasAggs)
parseCheckAggregates(pstate, qry); parseCheckAggregates(pstate, qry);
return (Query *) qry; return (Query *) qry;
......
...@@ -7,7 +7,7 @@ ...@@ -7,7 +7,7 @@
* *
* *
* IDENTIFICATION * IDENTIFICATION
* $Header: /cvsroot/pgsql/src/backend/parser/parse_agg.c,v 1.6 1998/01/05 03:32:25 momjian Exp $ * $Header: /cvsroot/pgsql/src/backend/parser/parse_agg.c,v 1.7 1998/01/15 18:59:59 momjian Exp $
* *
*------------------------------------------------------------------------- *-------------------------------------------------------------------------
*/ */
...@@ -34,64 +34,17 @@ static bool contain_agg_clause(Node *clause); ...@@ -34,64 +34,17 @@ static bool contain_agg_clause(Node *clause);
static bool exprIsAggOrGroupCol(Node *expr, List *groupClause); static bool exprIsAggOrGroupCol(Node *expr, List *groupClause);
static bool tleIsAggOrGroupCol(TargetEntry *tle, List *groupClause); static bool tleIsAggOrGroupCol(TargetEntry *tle, List *groupClause);
/*
* AddAggToParseState -
* add the aggregate to the list of unique aggregates in pstate.
*
* SIDE EFFECT: aggno in target list entry will be modified
*/
void
AddAggToParseState(ParseState *pstate, Aggreg *aggreg)
{
List *ag;
int i;
/*
* see if we have the aggregate already (we only need to record the
* aggregate once)
*/
i = 0;
foreach(ag, pstate->p_aggs)
{
Aggreg *a = lfirst(ag);
if (!strcmp(a->aggname, aggreg->aggname) &&
equal(a->target, aggreg->target))
{
/* fill in the aggno and we're done */
aggreg->aggno = i;
return;
}
i++;
}
/* not found, new aggregate */
aggreg->aggno = i;
pstate->p_numAgg++;
pstate->p_aggs = lappend(pstate->p_aggs, aggreg);
return;
}
/* /*
* finalizeAggregates - * finalizeAggregates -
* fill in qry_aggs from pstate. Also checks to make sure that aggregates * fill in hasAggs from pstate. Also checks to make sure that aggregates
* are used in the proper place. * are used in the proper place.
*/ */
void void
finalizeAggregates(ParseState *pstate, Query *qry) finalizeAggregates(ParseState *pstate, Query *qry)
{ {
List *l;
int i;
parseCheckAggregates(pstate, qry); parseCheckAggregates(pstate, qry);
qry->qry_numAgg = pstate->p_numAgg; qry->hasAggs = pstate->p_hasAggs;
qry->qry_aggs =
(Aggreg **) palloc(sizeof(Aggreg *) * qry->qry_numAgg);
i = 0;
foreach(l, pstate->p_aggs)
qry->qry_aggs[i++] = (Aggreg *) lfirst(l);
} }
/* /*
...@@ -240,7 +193,7 @@ parseCheckAggregates(ParseState *pstate, Query *qry) ...@@ -240,7 +193,7 @@ parseCheckAggregates(ParseState *pstate, Query *qry)
{ {
List *tl; List *tl;
Assert(pstate->p_numAgg > 0); Assert(pstate->p_hasAggs);
/* /*
* aggregates never appear in WHERE clauses. (we have to check where * aggregates never appear in WHERE clauses. (we have to check where
...@@ -393,6 +346,8 @@ ParseAgg(ParseState *pstate, char *aggname, Oid basetype, ...@@ -393,6 +346,8 @@ ParseAgg(ParseState *pstate, char *aggname, Oid basetype,
if (usenulls) if (usenulls)
aggreg->usenulls = true; aggreg->usenulls = true;
pstate->p_hasAggs = true;
return aggreg; return aggreg;
} }
......
...@@ -7,7 +7,7 @@ ...@@ -7,7 +7,7 @@
* *
* *
* IDENTIFICATION * IDENTIFICATION
* $Header: /cvsroot/pgsql/src/backend/parser/parse_func.c,v 1.5 1998/01/05 03:32:28 momjian Exp $ * $Header: /cvsroot/pgsql/src/backend/parser/parse_func.c,v 1.6 1998/01/15 19:00:02 momjian Exp $
* *
*------------------------------------------------------------------------- *-------------------------------------------------------------------------
*/ */
...@@ -221,13 +221,8 @@ ParseFunc(ParseState *pstate, char *funcname, List *fargs, ...@@ -221,13 +221,8 @@ ParseFunc(ParseState *pstate, char *funcname, List *fargs,
PointerGetDatum(funcname), PointerGetDatum(funcname),
ObjectIdGetDatum(basetype), ObjectIdGetDatum(basetype),
0, 0)) 0, 0))
{ return (Node *)ParseAgg(pstate, funcname, basetype,
Aggreg *aggreg = ParseAgg(pstate, funcname, basetype,
fargs, precedence); fargs, precedence);
AddAggToParseState(pstate, aggreg);
return (Node *) aggreg;
}
} }
} }
......
...@@ -7,7 +7,7 @@ ...@@ -7,7 +7,7 @@
* *
* *
* IDENTIFICATION * IDENTIFICATION
* $Header: /cvsroot/pgsql/src/backend/parser/parse_node.c,v 1.5 1998/01/05 03:32:29 momjian Exp $ * $Header: /cvsroot/pgsql/src/backend/parser/parse_node.c,v 1.6 1998/01/15 19:00:04 momjian Exp $
* *
*------------------------------------------------------------------------- *-------------------------------------------------------------------------
*/ */
...@@ -49,8 +49,7 @@ make_parsestate(void) ...@@ -49,8 +49,7 @@ make_parsestate(void)
pstate = palloc(sizeof(ParseState)); pstate = palloc(sizeof(ParseState));
pstate->p_last_resno = 1; pstate->p_last_resno = 1;
pstate->p_rtable = NIL; pstate->p_rtable = NIL;
pstate->p_numAgg = 0; pstate->p_hasAggs = false;
pstate->p_aggs = NIL;
pstate->p_is_insert = false; pstate->p_is_insert = false;
pstate->p_insert_columns = NIL; pstate->p_insert_columns = NIL;
pstate->p_is_update = false; pstate->p_is_update = false;
......
...@@ -6,7 +6,7 @@ ...@@ -6,7 +6,7 @@
* *
* *
* IDENTIFICATION * IDENTIFICATION
* $Header: /cvsroot/pgsql/src/backend/rewrite/Attic/locks.c,v 1.6 1998/01/04 04:31:27 momjian Exp $ * $Header: /cvsroot/pgsql/src/backend/rewrite/Attic/locks.c,v 1.7 1998/01/15 19:00:06 momjian Exp $
* *
*------------------------------------------------------------------------- *-------------------------------------------------------------------------
*/ */
...@@ -95,7 +95,6 @@ thisLockWasTriggered(int varno, ...@@ -95,7 +95,6 @@ thisLockWasTriggered(int varno,
AttrNumber attnum, AttrNumber attnum,
Query *parsetree) Query *parsetree)
{ {
int i;
if (nodeThisLockWasTriggered(parsetree->qual, varno, attnum)) if (nodeThisLockWasTriggered(parsetree->qual, varno, attnum))
return true; return true;
...@@ -103,10 +102,6 @@ thisLockWasTriggered(int varno, ...@@ -103,10 +102,6 @@ thisLockWasTriggered(int varno,
if (nodeThisLockWasTriggered((Node *) parsetree->targetList, varno, attnum)) if (nodeThisLockWasTriggered((Node *) parsetree->targetList, varno, attnum))
return true; return true;
for(i=0; i < parsetree->qry_numAgg; i++)
if (nodeThisLockWasTriggered(parsetree->qry_aggs[i]->target,
varno, attnum))
return true;
return false; return false;
} }
......
...@@ -6,7 +6,7 @@ ...@@ -6,7 +6,7 @@
* *
* *
* IDENTIFICATION * IDENTIFICATION
* $Header: /cvsroot/pgsql/src/backend/rewrite/rewriteManip.c,v 1.9 1998/01/04 04:31:29 momjian Exp $ * $Header: /cvsroot/pgsql/src/backend/rewrite/rewriteManip.c,v 1.10 1998/01/15 19:00:07 momjian Exp $
* *
*------------------------------------------------------------------------- *-------------------------------------------------------------------------
*/ */
...@@ -420,16 +420,12 @@ HandleRIRAttributeRule(Query *parsetree, ...@@ -420,16 +420,12 @@ HandleRIRAttributeRule(Query *parsetree,
int *modified, int *modified,
int *badsql) int *badsql)
{ {
int i;
nodeHandleRIRAttributeRule((Node **) (&(parsetree->targetList)), rtable, nodeHandleRIRAttributeRule((Node **) (&(parsetree->targetList)), rtable,
targetlist, rt_index, attr_num, targetlist, rt_index, attr_num,
modified, badsql); modified, badsql);
nodeHandleRIRAttributeRule(&parsetree->qual, rtable, targetlist, nodeHandleRIRAttributeRule(&parsetree->qual, rtable, targetlist,
rt_index, attr_num, modified, badsql); rt_index, attr_num, modified, badsql);
for(i=0; i < parsetree->qry_numAgg; i++)
nodeHandleRIRAttributeRule(&parsetree->qry_aggs[i]->target, rtable,
targetlist, rt_index, attr_num, modified, badsql);
} }
...@@ -521,13 +517,9 @@ HandleViewRule(Query *parsetree, ...@@ -521,13 +517,9 @@ HandleViewRule(Query *parsetree,
int rt_index, int rt_index,
int *modified) int *modified)
{ {
int i;
nodeHandleViewRule(&parsetree->qual, rtable, targetlist, rt_index, nodeHandleViewRule(&parsetree->qual, rtable, targetlist, rt_index,
modified); modified);
nodeHandleViewRule((Node **) (&(parsetree->targetList)), rtable, targetlist, nodeHandleViewRule((Node **) (&(parsetree->targetList)), rtable, targetlist,
rt_index, modified); rt_index, modified);
for(i=0; i < parsetree->qry_numAgg; i++)
nodeHandleViewRule(&parsetree->qry_aggs[i]->target, rtable, targetlist, rt_index,
modified);
} }
...@@ -6,7 +6,7 @@ ...@@ -6,7 +6,7 @@
* *
* Copyright (c) 1994, Regents of the University of California * Copyright (c) 1994, Regents of the University of California
* *
* $Id: parsenodes.h,v 1.43 1998/01/11 03:41:49 momjian Exp $ * $Id: parsenodes.h,v 1.44 1998/01/15 19:00:11 momjian Exp $
* *
*------------------------------------------------------------------------- *-------------------------------------------------------------------------
*/ */
...@@ -44,6 +44,7 @@ typedef struct Query ...@@ -44,6 +44,7 @@ typedef struct Query
bool isPortal; /* is this a retrieve into portal? */ bool isPortal; /* is this a retrieve into portal? */
bool isBinary; /* binary portal? */ bool isBinary; /* binary portal? */
bool unionall; /* union without unique sort */ bool unionall; /* union without unique sort */
bool hasAggs; /* has aggregates in target list */
char *uniqueFlag; /* NULL, '*', or Unique attribute name */ char *uniqueFlag; /* NULL, '*', or Unique attribute name */
List *sortClause; /* a list of SortClause's */ List *sortClause; /* a list of SortClause's */
...@@ -56,9 +57,6 @@ typedef struct Query ...@@ -56,9 +57,6 @@ typedef struct Query
* BY */ * BY */
Node *havingQual; /* qualification of each group */ Node *havingQual; /* qualification of each group */
int qry_numAgg; /* number of aggregates in the target list */
Aggreg **qry_aggs; /* the aggregates */
List *unionClause; /* unions are linked under the previous query */ List *unionClause; /* unions are linked under the previous query */
/* internal to planner */ /* internal to planner */
......
...@@ -6,7 +6,7 @@ ...@@ -6,7 +6,7 @@
* *
* Copyright (c) 1994, Regents of the University of California * Copyright (c) 1994, Regents of the University of California
* *
* $Id: plannodes.h,v 1.12 1997/12/27 06:41:41 momjian Exp $ * $Id: plannodes.h,v 1.13 1998/01/15 19:00:13 momjian Exp $
* *
*------------------------------------------------------------------------- *-------------------------------------------------------------------------
*/ */
...@@ -214,8 +214,7 @@ typedef struct HashJoin ...@@ -214,8 +214,7 @@ typedef struct HashJoin
typedef struct Agg typedef struct Agg
{ {
Plan plan; Plan plan;
int numAgg; List *aggs;
Aggreg **aggs;
AggState *aggstate; AggState *aggstate;
} Agg; } Agg;
......
...@@ -6,7 +6,7 @@ ...@@ -6,7 +6,7 @@
* *
* Copyright (c) 1994, Regents of the University of California * Copyright (c) 1994, Regents of the University of California
* *
* $Id: planmain.h,v 1.9 1997/12/20 07:59:43 momjian Exp $ * $Id: planmain.h,v 1.10 1998/01/15 19:00:15 momjian Exp $
* *
*------------------------------------------------------------------------- *-------------------------------------------------------------------------
*/ */
...@@ -33,7 +33,7 @@ extern SeqScan *make_seqscan(List *qptlist, List *qpqual, Index scanrelid, ...@@ -33,7 +33,7 @@ extern SeqScan *make_seqscan(List *qptlist, List *qpqual, Index scanrelid,
Plan *lefttree); Plan *lefttree);
extern Sort *make_sort(List *tlist, Oid tempid, Plan *lefttree, extern Sort *make_sort(List *tlist, Oid tempid, Plan *lefttree,
int keycount); int keycount);
extern Agg *make_agg(List *tlist, int nagg, Aggreg **aggs, Plan *lefttree); extern Agg *make_agg(List *tlist, Plan *lefttree);
extern Group *make_group(List *tlist, bool tuplePerGroup, int ngrp, extern Group *make_group(List *tlist, bool tuplePerGroup, int ngrp,
AttrNumber *grpColIdx, Sort *lefttree); AttrNumber *grpColIdx, Sort *lefttree);
extern Unique *make_unique(List *tlist, Plan *lefttree, char *uniqueAttr); extern Unique *make_unique(List *tlist, Plan *lefttree, char *uniqueAttr);
...@@ -55,7 +55,7 @@ extern List *join_references(List *clauses, List *outer_tlist, ...@@ -55,7 +55,7 @@ extern List *join_references(List *clauses, List *outer_tlist,
extern List *index_outerjoin_references(List *inner_indxqual, extern List *index_outerjoin_references(List *inner_indxqual,
List *outer_tlist, Index inner_relid); List *outer_tlist, Index inner_relid);
extern void set_result_tlist_references(Result *resultNode); extern void set_result_tlist_references(Result *resultNode);
extern void set_agg_tlist_references(Agg *aggNode); extern List *set_agg_tlist_references(Agg *aggNode);
extern void set_agg_agglist_references(Agg *aggNode); extern void set_agg_agglist_references(Agg *aggNode);
extern void del_agg_tlist_references(List *tlist); extern void del_agg_tlist_references(List *tlist);
......
...@@ -5,7 +5,7 @@ ...@@ -5,7 +5,7 @@
* *
* Copyright (c) 1994, Regents of the University of California * Copyright (c) 1994, Regents of the University of California
* *
* $Id: parse_node.h,v 1.3 1997/11/26 03:43:13 momjian Exp $ * $Id: parse_node.h,v 1.4 1998/01/15 19:00:16 momjian Exp $
* *
*------------------------------------------------------------------------- *-------------------------------------------------------------------------
*/ */
...@@ -30,10 +30,9 @@ typedef struct ParseState ...@@ -30,10 +30,9 @@ typedef struct ParseState
{ {
int p_last_resno; int p_last_resno;
List *p_rtable; List *p_rtable;
int p_numAgg;
List *p_aggs;
bool p_is_insert;
List *p_insert_columns; List *p_insert_columns;
bool p_hasAggs;
bool p_is_insert;
bool p_is_update; bool p_is_update;
bool p_is_rule; bool p_is_rule;
bool p_in_where_clause; bool p_in_where_clause;
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment