Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
Greenplum
Gpdb
提交
1c1ecd51
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,发现更多精彩内容 >>
提交
1c1ecd51
编写于
6月 28, 2006
作者:
T
Tom Lane
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
Improve planner estimates for size of tuple hash tables.
上级
485375a1
变更
2
隐藏空白更改
内联
并排
Showing
2 changed file
with
8 addition
and
6 deletion
+8
-6
src/backend/optimizer/plan/planner.c
src/backend/optimizer/plan/planner.c
+2
-2
src/backend/optimizer/plan/subselect.c
src/backend/optimizer/plan/subselect.c
+6
-4
未找到文件。
src/backend/optimizer/plan/planner.c
浏览文件 @
1c1ecd51
...
...
@@ -8,7 +8,7 @@
*
*
* IDENTIFICATION
* $PostgreSQL: pgsql/src/backend/optimizer/plan/planner.c,v 1.
199 2006/03/05 15:58:29 momjian
Exp $
* $PostgreSQL: pgsql/src/backend/optimizer/plan/planner.c,v 1.
200 2006/06/28 20:04:38 tgl
Exp $
*
*-------------------------------------------------------------------------
*/
...
...
@@ -1298,7 +1298,7 @@ choose_hashed_grouping(PlannerInfo *root, double tuple_fraction,
}
/* Estimate per-hash-entry space at tuple width... */
hashentrysize
=
cheapest_path_width
;
hashentrysize
=
MAXALIGN
(
cheapest_path_width
)
+
MAXALIGN
(
sizeof
(
MinimalTupleData
))
;
/* plus space for pass-by-ref transition values... */
hashentrysize
+=
agg_counts
->
transitionSpace
;
/* plus the per-hash-entry overhead */
...
...
src/backend/optimizer/plan/subselect.c
浏览文件 @
1c1ecd51
...
...
@@ -7,7 +7,7 @@
* Portions Copyright (c) 1994, Regents of the University of California
*
* IDENTIFICATION
* $PostgreSQL: pgsql/src/backend/optimizer/plan/subselect.c,v 1.10
7 2006/05/03 00:24:56
tgl Exp $
* $PostgreSQL: pgsql/src/backend/optimizer/plan/subselect.c,v 1.10
8 2006/06/28 20:04:38
tgl Exp $
*
*-------------------------------------------------------------------------
*/
...
...
@@ -585,11 +585,13 @@ subplan_is_hashable(SubLink *slink, SubPlan *node)
return
false
;
/*
* The estimated size of the subquery result must fit in work_mem. (XXX
* what about hashtable overhead?)
* The estimated size of the subquery result must fit in work_mem.
* (Note: we use sizeof(HeapTupleHeaderData) here even though the tuples
* will actually be stored as MinimalTuples; this provides some fudge
* factor for hashtable overhead.)
*/
subquery_size
=
node
->
plan
->
plan_rows
*
(
MAXALIGN
(
node
->
plan
->
plan_width
)
+
MAXALIGN
(
sizeof
(
HeapTupleData
)));
(
MAXALIGN
(
node
->
plan
->
plan_width
)
+
MAXALIGN
(
sizeof
(
HeapTuple
Header
Data
)));
if
(
subquery_size
>
work_mem
*
1024L
)
return
false
;
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录