Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
Greenplum
Gpdb
提交
a65e4484
G
Gpdb
项目概览
Greenplum
/
Gpdb
通知
7
Star
1
Fork
0
代码
文件
提交
分支
Tags
贡献者
分支图
Diff
Issue
0
列表
看板
标记
里程碑
合并请求
0
DevOps
流水线
流水线任务
计划
Wiki
0
Wiki
分析
仓库
DevOps
项目成员
Pages
G
Gpdb
项目概览
项目概览
详情
发布
仓库
仓库
文件
提交
分支
标签
贡献者
分支图
比较
Issue
0
Issue
0
列表
看板
标记
里程碑
合并请求
0
合并请求
0
Pages
DevOps
DevOps
流水线
流水线任务
计划
分析
分析
仓库分析
DevOps
Wiki
0
Wiki
成员
成员
收起侧边栏
关闭侧边栏
动态
分支图
创建新Issue
流水线任务
提交
Issue看板
体验新版 GitCode,发现更多精彩内容 >>
提交
a65e4484
编写于
1月 04, 1998
作者:
B
Bruce Momjian
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
Fix for aggs on views and complex ones. I missed one file.
上级
4b05912f
变更
1
隐藏空白更改
内联
并排
Showing
1 changed file
with
18 addition
and
10 deletion
+18
-10
src/backend/parser/parse_expr.c
src/backend/parser/parse_expr.c
+18
-10
未找到文件。
src/backend/parser/parse_expr.c
浏览文件 @
a65e4484
...
...
@@ -7,7 +7,7 @@
*
*
* IDENTIFICATION
* $Header: /cvsroot/pgsql/src/backend/parser/parse_expr.c,v 1.
4 1997/12/23 19:36:20 thomas
Exp $
* $Header: /cvsroot/pgsql/src/backend/parser/parse_expr.c,v 1.
5 1998/01/04 04:53:50 momjian
Exp $
*
*-------------------------------------------------------------------------
*/
...
...
@@ -55,7 +55,8 @@ transformExpr(ParseState *pstate, Node *expr, int precedence)
Node
*
temp
;
/* what if att.attrs == "*"?? */
temp
=
handleNestedDots
(
pstate
,
att
,
&
pstate
->
p_last_resno
);
temp
=
handleNestedDots
(
pstate
,
att
,
&
pstate
->
p_last_resno
,
precedence
);
if
(
att
->
indirection
!=
NIL
)
{
List
*
idx
=
att
->
indirection
;
...
...
@@ -156,7 +157,8 @@ transformExpr(ParseState *pstate, Node *expr, int precedence)
result
=
ParseFunc
(
pstate
,
"nullvalue"
,
lcons
(
lexpr
,
NIL
),
&
pstate
->
p_last_resno
);
&
pstate
->
p_last_resno
,
precedence
);
}
break
;
case
NOTNULL
:
...
...
@@ -165,7 +167,8 @@ transformExpr(ParseState *pstate, Node *expr, int precedence)
result
=
ParseFunc
(
pstate
,
"nonnullvalue"
,
lcons
(
lexpr
,
NIL
),
&
pstate
->
p_last_resno
);
&
pstate
->
p_last_resno
,
precedence
);
}
break
;
case
AND
:
...
...
@@ -242,7 +245,8 @@ transformExpr(ParseState *pstate, Node *expr, int precedence)
foreach
(
args
,
fn
->
args
)
lfirst
(
args
)
=
transformExpr
(
pstate
,
(
Node
*
)
lfirst
(
args
),
precedence
);
result
=
ParseFunc
(
pstate
,
fn
->
funcname
,
fn
->
args
,
&
pstate
->
p_last_resno
);
fn
->
funcname
,
fn
->
args
,
&
pstate
->
p_last_resno
,
precedence
);
break
;
}
default:
...
...
@@ -273,7 +277,8 @@ transformIdent(ParseState *pstate, Node *expr, int precedence)
att
->
relname
=
rte
->
refname
;
att
->
attrs
=
lcons
(
makeString
(
ident
->
name
),
NIL
);
column_result
=
(
Node
*
)
handleNestedDots
(
pstate
,
att
,
&
pstate
->
p_last_resno
);
(
Node
*
)
handleNestedDots
(
pstate
,
att
,
&
pstate
->
p_last_resno
,
precedence
);
}
/* try to find the ident as a relation */
...
...
@@ -358,7 +363,7 @@ exprType(Node *expr)
** a tree with of Iter and Func nodes.
*/
Node
*
handleNestedDots
(
ParseState
*
pstate
,
Attr
*
attr
,
int
*
curr_resno
)
handleNestedDots
(
ParseState
*
pstate
,
Attr
*
attr
,
int
*
curr_resno
,
int
precedence
)
{
List
*
mutator_iter
;
Node
*
retval
=
NULL
;
...
...
@@ -370,7 +375,8 @@ handleNestedDots(ParseState *pstate, Attr *attr, int *curr_resno)
retval
=
ParseFunc
(
pstate
,
strVal
(
lfirst
(
attr
->
attrs
)),
lcons
(
param
,
NIL
),
curr_resno
);
curr_resno
,
precedence
);
}
else
{
...
...
@@ -381,14 +387,16 @@ handleNestedDots(ParseState *pstate, Attr *attr, int *curr_resno)
retval
=
ParseFunc
(
pstate
,
strVal
(
lfirst
(
attr
->
attrs
)),
lcons
(
ident
,
NIL
),
curr_resno
);
curr_resno
,
precedence
);
}
foreach
(
mutator_iter
,
lnext
(
attr
->
attrs
))
{
retval
=
ParseFunc
(
pstate
,
strVal
(
lfirst
(
mutator_iter
)),
lcons
(
retval
,
NIL
),
curr_resno
);
curr_resno
,
precedence
);
}
return
(
retval
);
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录