Nested loop and simple join query - slow after upgrade to 9.2

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

 



Hi,

Last weekend, we upgrade a PG from 8.4 to 9.2 version (full pg_dump/restore/vacuum/analyze). After this, some simple join querys became very slow, maybe because the use of nested loops. Bellow, an example with nestedloop on and off:

base=# analyze verbose pc13t;
INFO:  analyzing "public.pc13t"
INFO: "pc13t": scanned 30000 of 212313 pages, containing 268677 live rows and 764 dead rows; 30000 rows in sample, 1903065 estimated total rows
ANALYZE
base=# analyze verbose pc13t3;
INFO:  analyzing "public.pc13t3"
INFO: "pc13t3": scanned 30000 of 883424 pages, containing 1274216 live rows and 3005 dead rows; 30000 rows in sample, 37553206 estimated total rows
ANALYZE
base=# set enable_nestloop = on;
SET
base=# explain (analyze,buffers) SELECT T1.Pc13Item, T1.PC13CodPed, T1.PC13AnoPed, T1.PC13Emp08P, T1.PC13Cor, T1.PC13Codigo, T1.PC13Emp08, T1.PC13ProEst AS PC13ProEst, T2.PC13Grade, T4.PC07GerPed, T2.PC13EmpGra, T1.PC13Emp06P AS PC13Emp06P, T4.PC07NaoTV, T3.co13PorTam, T4.PC07CodAlm, T4.PC07C_Cust AS PC13SecIns, T3.co13Bloq AS PC13ProBlq, T1.PC13InsEst AS PC13InsEst, T1.PC13TipIn2 AS PC13TipIn2, T1.PC13EmpIns AS PC13EmpIns FROM (((PC13T3 T1 LEFT JOIN PC13T T2 ON T2.PC13Emp08 = T1.PC13Emp08 AND T2.PC13Codigo = T1.PC13Codigo AND T2.PC13Cor = T1.PC13Cor AND T2.PC13Emp08P = T1.PC13Emp08P AND T2.PC13AnoPed = T1.PC13AnoPed AND T2.PC13CodPed = T1.PC13CodPed AND T2.Pc13Item = T1.Pc13Item) LEFT JOIN CO13T T3 ON T3.co13Emp06 = T1.PC13Emp06P AND T3.co13CodPro = T1.PC13ProEst) LEFT JOIN PC07T T4 ON T4.PC07CodEmp = T1.PC13EmpIns AND T4.PC07Tipo = T1.PC13TipIn2 AND T4.PC07Codigo = T1.PC13InsEst) WHERE T1.PC13Emp08 = '1' and T1.PC13Codigo = E'9487-491C ' and T1.PC13Cor = '1' and T1.PC13Emp08P = '0' and T1.PC13AnoPed = '0' and T1.PC13CodPed = '0' and T1.Pc13Item = '0' ORDER BY T1.PC13Emp08, T1.PC13Codigo, T1.PC13Cor, T1.PC13Emp08P, T1.PC13AnoPed, T1.PC13CodPed, T1.Pc13Item, T1.PC13EmpIns, T1.PC13TipIn2, T1.PC13InsEst ;

QUERY PLAN


---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------
-----------------------------
Nested Loop Left Join (cost=0.00..20.61 rows=1 width=86) (actual time=0.870..1197.057 rows=39 loops=1)
   Buffers: shared hit=424602 read=5
-> Nested Loop Left Join (cost=0.00..16.33 rows=1 width=74) (actual time=0.822..1196.583 rows=39 loops=1)
         Buffers: shared hit=424484 read=5
-> Nested Loop Left Join (cost=0.00..12.01 rows=1 width=70) (actual time=0.779..1195.477 rows=39 loops=1) Join Filter: ((t2.pc13emp08 = t1.pc13emp08) AND (t2.pc13codigo = t1.pc13codigo) AND (t2.pc13cor = t1.pc13cor) AND (t2.pc13emp08p = t1.pc13emp08p) AND (t2.pc13anoped = t1.pc13anoped) AND (t2.pc13codped = t1.pc13codped) AND
(t2.pc13item = t1.pc13item))
               Buffers: shared hit=424329 read=5
-> Index Scan using ad_pc13t3_modpadrao on pc13t3 t1 (cost=0.00..6.21 rows=1 width=65) (actual time=0.090..0.252 rows=39 loops=1) Index Cond: ((pc13emp08p = 0) AND (pc13anoped = 0) AND (pc13codped = 0) AND (pc13codigo = '9487-491C '::bpchar) AND (pc13cor = 1) AND (pc13emp08 = 1))
                     Buffers: shared hit=5 read=5
-> Index Scan using xpc13tc on pc13t t2 (cost=0.00..5.77 rows=1 width=44) (actual time=0.254..30.638 rows=1 loops=39) Index Cond: ((pc13emp08p = 0) AND (pc13anoped = 0) AND (pc13codped = 0) AND (pc13item = 0)) Filter: ((pc13emp08 = 1) AND (pc13codigo = '9487-491C '::bpchar) AND (pc13cor = 1))
                     Rows Removed by Filter: 45161
                     Buffers: shared hit=424324
-> Index Scan using co13t_pkey on co13t t3 (cost=0.00..4.31 rows=1 width=10) (actual time=0.021..0.024 rows=1 loops=39) Index Cond: ((co13emp06 = t1.pc13emp06p) AND (co13codpro = t1.pc13proest))
               Buffers: shared hit=155
-> Index Scan using pc07t_pkey on pc07t t4 (cost=0.00..4.28 rows=1 width=24) (actual time=0.008..0.009 rows=1 loops=39) Index Cond: ((pc07codemp = t1.pc13empins) AND (pc07tipo = t1.pc13tipin2) AND (pc07codigo = t1.pc13insest))
         Buffers: shared hit=118
 Total runtime: 1197.332 ms
(22 rows)

#######################################################

base=# set enable_nestloop = off;
SET
base=# explain (analyze,buffers) SELECT T1.Pc13Item, T1.PC13CodPed, T1.PC13AnoPed, T1.PC13Emp08P, T1.PC13Cor, T1.PC13Codigo, T1.PC13Emp08, T1.PC13ProEst AS PC13ProEst, T2.PC13Grade, T4.PC07GerPed, T2.PC13EmpGra, T1.PC13Emp06P AS PC13Emp06P, T4.PC07NaoTV, T3.co13PorTam, T4.PC07CodAlm, T4.PC07C_Cust AS PC13SecIns, T3.co13Bloq AS PC13ProBlq, T1.PC13InsEst AS PC13InsEst, T1.PC13TipIn2 AS PC13TipIn2, T1.PC13EmpIns AS PC13EmpIns FROM (((PC13T3 T1 LEFT JOIN PC13T T2 ON T2.PC13Emp08 = T1.PC13Emp08 AND T2.PC13Codigo = T1.PC13Codigo AND T2.PC13Cor = T1.PC13Cor AND T2.PC13Emp08P = T1.PC13Emp08P AND T2.PC13AnoPed = T1.PC13AnoPed AND T2.PC13CodPed = T1.PC13CodPed AND T2.Pc13Item = T1.Pc13Item) LEFT JOIN CO13T T3 ON T3.co13Emp06 = T1.PC13Emp06P AND T3.co13CodPro = T1.PC13ProEst) LEFT JOIN PC07T T4 ON T4.PC07CodEmp = T1.PC13EmpIns AND T4.PC07Tipo = T1.PC13TipIn2 AND T4.PC07Codigo = T1.PC13InsEst) WHERE T1.PC13Emp08 = '1' and T1.PC13Codigo = E'9487-491C ' and T1.PC13Cor = '1' and T1.PC13Emp08P = '0' and T1.PC13AnoPed = '0' and T1.PC13CodPed = '0' and T1.Pc13Item = '0' ORDER BY T1.PC13Emp08, T1.PC13Codigo, T1.PC13Cor, T1.PC13Emp08P, T1.PC13AnoPed, T1.PC13CodPed, T1.Pc13Item, T1.PC13EmpIns, T1.PC13TipIn2, T1.PC13InsEst ;

QUERY PLAN


---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------
---------------------
Sort (cost=7782.21..7782.21 rows=1 width=86) (actual time=108.672..108.677 rows=39 loops=1)
   Sort Key: t1.pc13empins, t1.pc13tipin2, t1.pc13insest
   Sort Method: quicksort  Memory: 30kB
   Buffers: shared hit=15960 read=2050
-> Hash Left Join (cost=154.42..7782.20 rows=1 width=86) (actual time=49.398..108.413 rows=39 loops=1) Hash Cond: ((t1.pc13emp08 = t2.pc13emp08) AND (t1.pc13codigo = t2.pc13codigo) AND (t1.pc13cor = t2.pc13cor) AND (t1.pc13emp08p = t2.pc13emp08p) AND (t1.pc13anoped = t2.pc13anoped) AND (t1.pc13codped = t2.pc13codped) AND (t1.pc13
item = t2.pc13item))
         Buffers: shared hit=15960 read=2050
-> Hash Right Join (cost=148.62..7776.37 rows=1 width=81) (actual time=6.392..65.317 rows=39 loops=1) Hash Cond: ((t3.co13emp06 = t1.pc13emp06p) AND (t3.co13codpro = t1.pc13proest))
               Buffers: shared hit=5073 read=2050
-> Seq Scan on co13t t3 (cost=0.00..7371.56 rows=34156 width=10) (actual time=0.009..41.550 rows=34156 loops=1)
                     Buffers: shared hit=5043 read=1987
-> Hash (cost=148.61..148.61 rows=1 width=77) (actual time=2.514..2.514 rows=39 loops=1)
                     Buckets: 1024  Batches: 1  Memory Usage: 5kB
                     Buffers: shared hit=27 read=63
-> Hash Right Join (cost=6.23..148.61 rows=1 width=77) (actual time=0.141..2.484 rows=39 loops=1) Hash Cond: ((t4.pc07codemp = t1.pc13empins) AND (t4.pc07tipo = t1.pc13tipin2) AND (t4.pc07codigo = t1.pc13insest))
                           Buffers: shared hit=27 read=63
-> Seq Scan on pc07t t4 (cost=0.00..109.88 rows=2888 width=24) (actual time=0.002..1.171 rows=2888 loops=1)
                                 Buffers: shared hit=18 read=63
-> Hash (cost=6.21..6.21 rows=1 width=65) (actual time=0.123..0.123 rows=39 loops=1) Buckets: 1024 Batches: 1 Memory Usage: 4kB
                                 Buffers: shared hit=9
-> Index Scan using ad_pc13t3_modpadrao on pc13t3 t1 (cost=0.00..6.21 rows=1 width=65) (actual time=0.041..0.090 rows=39 loops=1) Index Cond: ((pc13emp08p = 0) AND (pc13anoped = 0) AND (pc13codped = 0) AND (pc13codigo = '9487-491C '::bpchar) AND (pc13cor = 1) AND (pc13emp08 = 1))
                                       Buffers: shared hit=9
-> Hash (cost=5.77..5.77 rows=1 width=44) (actual time=42.937..42.937 rows=1 loops=1)
               Buckets: 1024  Batches: 1  Memory Usage: 1kB
               Buffers: shared hit=10880
-> Index Scan using xpc13tc on pc13t t2 (cost=0.00..5.77 rows=1 width=44) (actual time=0.357..42.933 rows=1 loops=1) Index Cond: ((pc13emp08p = 0) AND (pc13anoped = 0) AND (pc13codped = 0) AND (pc13item = 0)) Filter: ((pc13emp08 = 1) AND (pc13codigo = '9487-491C '::bpchar) AND (pc13cor = 1))
                     Rows Removed by Filter: 45161
                     Buffers: shared hit=10880
 Total runtime: 108.884 ms
(35 rows)



Nested loop is ~12 times slower in this case. The server parameters are the same. Unfortunattly, I don't have the explain in 8.4 version.
And I noticed that the server load grew after the upgrade.

Best regards,

Alexandre



--
Sent via pgsql-performance mailing list (pgsql-performance@xxxxxxxxxxxxxx)
To make changes to your subscription:
http://www.postgresql.org/mailpref/pgsql-performance


[Postgresql General]     [Postgresql PHP]     [PHP Users]     [PHP Home]     [PHP on Windows]     [Kernel Newbies]     [PHP Classes]     [PHP Books]     [PHP Databases]     [Yosemite]

  Powered by Linux