Re: [INTERFACES] Back end memory consumption (was Front end memory consumption in SELECT) - Mailing list pgsql-interfaces
| From | Douglas Thomson |
|---|---|
| Subject | Re: [INTERFACES] Back end memory consumption (was Front end memory consumption in SELECT) |
| Date | |
| Msg-id | 199912030212.NAA16861@mugca.cc.monash.edu.au Whole thread Raw |
| In response to | Re: [INTERFACES] Back end memory consumption (was Front end memory consumption in SELECT) (Tom Lane <tgl@sss.pgh.pa.us>) |
| Responses |
Re: [INTERFACES] Back end memory consumption (was Front end memory consumption in SELECT)
Re: [INTERFACES] Back end memory consumption (was Front end memory consumption in SELECT) |
| List | pgsql-interfaces |
Tom Lane <tgl@sss.pgh.pa.us> writes:
> Douglas Thomson <dougt@mugc.cc.monash.edu.au> writes:
> > I have just noticed that the back end process swells to
> > the total size of all the tables involved in my query for the
> > duration of the SELECT (or is it the duration of the declared cursor
> > now?).
>
> The life of the cursor, probably, but I'm a little surprised by this.
>
> > To summarise the situation:
> > - I am attempting a join on 9 tables, using a cursor to fetch the
> > selected data
> > - the back end process grows to over 20M while processing my query
>
> What query plan does EXPLAIN show for your SELECT?
OK, here goes! I don't profess to understand the output from EXPLAIN,
so here it is verbatim. If I hadn't checked that I have indexes on
all the attributes (and attribute combinations) that make up the keys
needed for the join, I would think the back end was trying to read in
and sort a large part of the data just for the query!
NOTICE: _outNode: don't know how to print type 21
NOTICE: QUERY DUMP:
{ NESTLOOP :cost 0 :size 600832 :width 240 :state <> :qptargetlist ({ TARGETENTRY :resdom { RESDOM :resno 1 :restype 25
:restypmod-1 :resname "name" :reskey 0 :reskeyop 0 :resgroupref 0 :resjunk false } :expr { VAR :varno 65000 :varattno
11:vartype 25 :vartypmod -1 :varlevelsup 0 :varnoold 9 :varoattno 2}} { TARGETENTRY :resdom { RESDOM :resno 2 :restype
25:restypmod -1 :resname "canonical" :reskey 0 :reskeyop 0 :resgroupref 0 :resjunk false } :expr { VAR :varno 65000
:varattno15 :vartype 25 :vartypmod -1 :varlevelsup 0 :varnoold 5 :varoattno 2}}) :qpqual ({ EXPR :typeOid 0 :opType
op:oper { OPER :opno 98 :opid 67 :opresulttype 16 } :args ({ VAR :varno 65000 :varattno 4 :vartype 25 :vartypmod -1
:varlevelsup0 :varnoold 2 :varoattno 6} { VAR :varno 65001 :varattno 2 :vartype 25 :vartypmod -1 :varlevelsup 0
:varnoold1 :varoattno 2})} { EXPR :typeOid 0 :opType op :oper { OPER :opno 98 :opid 67 :opresulttype 16 } :args ({ VAR
:varno65000 :varattno 3 :vartype 25 :vart!
ypmod -1 :varlevelsup 0 :varnoold 2 :varoattno 4} { VAR :varno 65001 :varattno 1 :vartype 25 :vartypmod -1
:varlevelsup0 :varnoold 1 :varoattno 1})}) :lefttree { SEQSCAN :cost 0 :size 0 :width 24 :state <> :qptargetlist ({
TARGETENTRY:resdom { RESDOM :resno 1 :restype 25 :restypmod -1 :resname "<>" :reskey 0 :reskeyop 0 :resgroupref 0
:resjunkfalse } :expr { VAR :varno 1 :varattno 1 :vartype 25 :vartypmod -1 :varlevelsup 0 :varnoold 1 :varoattno 1}} {
TARGETENTRY:resdom { RESDOM :resno 2 :restype 25 :restypmod -1 :resname "<>" :reskey 0 :reskeyop 0 :resgroupref 0
:resjunkfalse } :expr { VAR :varno 1 :varattno 2 :vartype 25 :vartypmod -1 :varlevelsup 0 :varnoold 1 :varoattno 2}})
:qpqual({ EXPR :typeOid 0 :opType op :oper { OPER :opno 98 :opid 67 :opresulttype 16 } :args ({ VAR :varno 1 :varattno
3:vartype 25 :vartypmod -1 :varlevelsup 0 :varnoold 1 :varoattno 3} { CONST :consttype 25 :constlen -1 :constisnull
false:constvalue 32 [ 32 0 0 0 47 83 117 98 !
106 101 99 116 115 47 49 57 57 57 47 115 101 109 49 47 71 67 79 47 49 56 49 50 ] :constbyval
false})}) :lefttree <> :righttree <> :extprm () :locprm () :initplan <> :nprm 0 :scanrelid 1 } :righttree { SEQSCAN
:cost3.64259e+07 :size 1073741849 :width 216 :state <> :qptargetlist ({ TARGETENTRY :resdom { RESDOM :resno 1 :restype
25:restypmod -1 :resname "<>" :reskey 0 :reskeyop 0 :resgroupref 0 :resjunk false } :expr { VAR :varno 0 :varattno 1
:vartype25 :vartypmod -1 :varlevelsup 0 :varnoold 0 :varoattno 1}} { TARGETENTRY :resdom { RESDOM :resno 2 :restype 25
:restypmod-1 :resname "<>" :reskey 0 :reskeyop 0 :resgroupref 0 :resjunk false } :expr { VAR :varno 0 :varattno 2
:vartype25 :vartypmod -1 :varlevelsup 0 :varnoold 0 :varoattno 3}} { TARGETENTRY :resdom { RESDOM :resno 3 :restype 25
:restypmod-1 :resname "<>" :reskey 0 :reskeyop 0 :resgroupref 0 :resjunk false } :expr { VAR :varno 0 :varattno 3
:vartype25 :vartypmod -1 :varlevelsup 0 :var!
noold 0 :varoattno 4}} { TARGETENTRY :resdom { RESDOM :resno 4 :restype 25 :restypmod -1 :resname "<>" :reskey 0
:reskeyop0 :resgroupref 0 :resjunk false } :expr { VAR :varno 0 :varattno 4 :vartype 25 :vartypmod -1 :varlevelsup 0
:varnoold0 :varoattno 6}} { TARGETENTRY :resdom { RESDOM :resno 5 :restype 25 :restypmod -1 :resname "<>" :reskey 0
:reskeyop0 :resgroupref 0 :resjunk false } :expr { VAR :varno 0 :varattno 5 :vartype 25 :vartypmod -1 :varlevelsup 0
:varnoold0 :varoattno 4}} { TARGETENTRY :resdom { RESDOM :resno 6 :restype 25 :restypmod -1 :resname "<>" :reskey 0
:reskeyop0 :resgroupref 0 :resjunk false } :expr { VAR :varno 0 :varattno 6 :vartype 25 :vartypmod -1 :varlevelsup 0
:varnoold0 :varoattno 8}} { TARGETENTRY :resdom { RESDOM :resno 7 :restype 25 :restypmod -1 :resname "<>" :reskey 0
:reskeyop0 :resgroupref 0 :resjunk false } :expr { VAR :varno 0 :varattno 7 :vartype 25 :vartypmod -1 :varlevelsup 0
:varnoold0 :varoattno 7}} { TARGETENTRY :resdom { !
RESDOM :resno 8 :restype 25 :restypmod -1 :resname "<>" :reskey 0 :reskeyop 0 :resgroupref 0 :resjunk false }NOTICE:
QUERYPLAN:
Nested Loop (cost=0.00 rows=600832 width=240)
-> Seq Scan on t25 agents (cost=0.00 rows=0 width=24)
-> Seq Scan (cost=36425892.00 rows=1073741849 width=216)
-> ??? (cost=36425892.00 rows=1073741849 width=216)
-> Merge Join (cost=36425892.00 rows=1073741849 width=216)
-> Merge Join (cost=8371644.00 rows=850088153 width=192)
-> Seq Scan (cost=8110708.50 rows=7333003 width=144)
-> Sort (cost=8110708.50 rows=7333003 width=144)
-> Hash Join (cost=13897.26 rows=7333003 width=144)
-> Hash Join (cost=4635.32 rows=280070 width=132)
-> Hash Join (cost=2674.97 rows=59324 width=120)
-> Hash Join (cost=2180.41 rows=14894 width=108)
-> Hash Join (cost=1705.82 rows=14315 width=96)
-> Seq Scan on t30 enrolments (cost=667.40
rows=14315width=72)
-> Hash (cost=302.51 rows=6955 width=24)
-> Seq Scan on t24 users (cost=302.51
rows=6955width=24)
-> Hash (cost=1.10 rows=3 width=12)
-> Seq Scan on t21 studymodes (cost=1.10 rows=3
width=12)
-> Hash (cost=1.53 rows=16 width=12)
-> Seq Scan on t29 periods (cost=1.53 rows=16 width=12)
-> Hash (cost=1.33 rows=10 width=12)
-> Seq Scan on t23 campuses (cost=1.33 rows=10 width=12)
-> Hash (cost=10.32 rows=252 width=12)
-> Seq Scan on t28 courses (cost=10.32 rows=252 width=12)
-> Seq Scan (cost=17962.40 rows=29831 width=48)
-> Sort (cost=17962.40 rows=29831 width=48)
-> Seq Scan on t27 offerings (cost=1457.42 rows=29831 width=48)
-> Index Scan using t26_unq_0 on t26 subjects (cost=894.95 rows=13439 width=24)
NOTICE: _outNode: don't know how to print type 21
Hope this means something to you,
Doug.
pgsql-interfaces by date: