explain.depesz.com

PostgreSQL's explain analyze made readable

Result: FETD

Settings
# exclusive inclusive rows x rows loops node
1. 2.104 1,253.360 ↑ 1.0 40 1

Subquery Scan on r (cost=4,252.89..204,037.66 rows=40 width=1,326) (actual time=427.295..1,253.360 rows=40 loops=1)

2. 0.071 405.576 ↑ 1.0 40 1

Limit (cost=4,252.89..4,255.09 rows=40 width=1,194) (actual time=405.170..405.576 rows=40 loops=1)

3. 15.636 405.505 ↑ 2.4 40 1

WindowAgg (cost=4,252.89..4,258.12 rows=95 width=1,194) (actual time=405.169..405.505 rows=40 loops=1)

4. 11.637 389.869 ↓ 70.3 6,679 1

Group (cost=4,252.89..4,256.93 rows=95 width=990) (actual time=370.543..389.869 rows=6,679 loops=1)

  • Group Key: trp."trpID", tpe."tpeID", tcl."tclID", tos."tosID", tpc."tpcID", tcb."tcbID", tbc."tbcID", tba."tbaID", tpe_empresa."tpeID", trec."trecID", ttb."ttbID", trem."tremID", tfu."tfuID", tpe_funcionario."tpeID", tct."tctID", tlsos."tlsosSituacao
5. 45.525 378.232 ↓ 140.2 13,317 1

Sort (cost=4,252.89..4,253.13 rows=95 width=990) (actual time=370.539..378.232 rows=13,317 loops=1)

  • Sort Key: trp."trpID", tpe."tpeID", tcl."tclID", tos."tosID", tpc."tpcID", tcb."tcbID", tbc."tbcID", tba."tbaID", tpe_empresa."tpeID", trec."trecID", ttb."ttbID", trem."tremID", tfu."tfuID", tpe_funcionario."tpeID", tct."tctID", tlsos."tlsosSituacao
  • Sort Method: external merge Disk: 10016kB
6. 47.792 332.707 ↓ 140.2 13,317 1

Hash Right Join (cost=2,274.86..4,249.77 rows=95 width=990) (actual time=264.800..332.707 rows=13,317 loops=1)

  • Hash Cond: (trpc."trpctrpID" = trp."trpID")
7. 22.100 22.100 ↑ 1.0 89,212 1

Seq Scan on "TabReceitaParcelaContabil" trpc (cost=0.00..1,638.79 rows=89,379 width=4) (actual time=0.010..22.100 rows=89,212 loops=1)

8. 14.679 262.815 ↓ 109.5 6,679 1

Hash (cost=2,274.10..2,274.10 rows=61 width=990) (actual time=262.815..262.815 rows=6,679 loops=1)

  • Buckets: 8192 (originally 1024) Batches: 2 (originally 1) Memory Usage: 4033kB
9. 4.840 248.136 ↓ 109.5 6,679 1

Hash Left Join (cost=249.21..2,274.10 rows=61 width=990) (actual time=3.832..248.136 rows=6,679 loops=1)

  • Hash Cond: (tcfos."tcfosID" = tct."tcttcfosID")
10. 4.650 243.027 ↓ 109.5 6,679 1

Hash Left Join (cost=223.35..2,247.32 rows=61 width=972) (actual time=3.554..243.027 rows=6,679 loops=1)

  • Hash Cond: (tos."tosID" = tcfos."tcfostosID")
11. 7.870 238.154 ↓ 109.5 6,679 1

Nested Loop Left Join (cost=212.48..2,236.19 rows=61 width=968) (actual time=3.323..238.154 rows=6,679 loops=1)

12. 7.720 230.284 ↓ 109.5 6,679 1

Nested Loop Left Join (cost=212.20..2,216.49 rows=61 width=959) (actual time=3.322..230.284 rows=6,679 loops=1)

13. 12.812 222.564 ↓ 109.5 6,679 1

Nested Loop Left Join (cost=212.07..2,206.32 rows=61 width=927) (actual time=3.320..222.564 rows=6,679 loops=1)

  • Join Filter: (tba."tbaID" = tbc."tbctbaID")
  • Rows Removed by Join Filter: 20494
14. 6.668 203.073 ↓ 109.5 6,679 1

Nested Loop Left Join (cost=212.07..2,201.61 rows=61 width=923) (actual time=3.311..203.073 rows=6,679 loops=1)

  • Join Filter: (tbc."tbcID" = tcb."tcbtbcID")
  • Rows Removed by Join Filter: 7136
15. 7.411 189.726 ↓ 109.5 6,679 1

Nested Loop (cost=212.07..2,198.76 rows=61 width=887) (actual time=3.302..189.726 rows=6,679 loops=1)

16. 30.845 168.957 ↓ 109.5 6,679 1

Nested Loop Left Join (cost=211.78..2,145.66 rows=61 width=849) (actual time=3.296..168.957 rows=6,679 loops=1)

  • Join Filter: (tcb."tcbID" = trp."trptcbID")
  • Rows Removed by Join Filter: 93548
17. 6.685 118.075 ↓ 109.5 6,679 1

Nested Loop (cost=210.25..2,083.28 rows=61 width=437) (actual time=3.201..118.075 rows=6,679 loops=1)

18. 3.327 84.030 ↓ 60.0 3,420 1

Nested Loop (cost=209.96..1,966.83 rows=57 width=143) (actual time=3.150..84.030 rows=3,420 loops=1)

19. 2.842 73.863 ↓ 60.0 3,420 1

Nested Loop Left Join (cost=209.68..1,946.86 rows=57 width=139) (actual time=3.143..73.863 rows=3,420 loops=1)

20. 2.149 64.181 ↓ 60.0 3,420 1

Nested Loop Left Join (cost=209.39..1,719.24 rows=57 width=119) (actual time=3.139..64.181 rows=3,420 loops=1)

21. 4.596 55.192 ↓ 60.0 3,420 1

Nested Loop Left Join (cost=209.12..1,701.63 rows=57 width=115) (actual time=3.135..55.192 rows=3,420 loops=1)

22. 3.850 43.756 ↓ 60.0 3,420 1

Nested Loop Left Join (cost=208.83..1,642.41 rows=57 width=81) (actual time=3.130..43.756 rows=3,420 loops=1)

23. 3.546 33.066 ↓ 60.0 3,420 1

Hash Join (cost=208.55..1,613.52 rows=57 width=58) (actual time=3.121..33.066 rows=3,420 loops=1)

  • Hash Cond: (tlsos."tlsostosID" = trec."trectosID")
24. 5.035 26.452 ↓ 60.9 4,994 1

Subquery Scan on tlsos (cost=0.29..1,403.97 rows=82 width=8) (actual time=0.020..26.452 rows=4,994 loops=1)

  • Filter: (tlsos.rr = 1)
  • Rows Removed by Filter: 11378
25. 13.781 21.417 ↑ 1.0 16,372 1

WindowAgg (cost=0.29..1,198.93 rows=16,403 width=20) (actual time=0.016..21.417 rows=16,372 loops=1)

26. 7.636 7.636 ↑ 1.0 16,372 1

Index Scan using idx_tlsos_tlsostosdesc on "TabLogSituacaoOrdemServico" (cost=0.29..911.88 rows=16,403 width=12) (actual time=0.010..7.636 rows=16,372 loops=1)

27. 1.354 3.068 ↑ 1.0 3,420 1

Hash (cost=165.10..165.10 rows=3,453 width=54) (actual time=3.068..3.068 rows=3,420 loops=1)

  • Buckets: 4096 Batches: 1 Memory Usage: 317kB
28. 1.714 1.714 ↑ 1.0 3,437 1

Seq Scan on "TabReceita" trec (cost=0.00..165.10 rows=3,453 width=54) (actual time=0.009..1.714 rows=3,437 loops=1)

  • Filter: ("trectemID" = 1)
  • Rows Removed by Filter: 2910
29. 6.840 6.840 ↑ 1.0 1 3,420

Index Scan using "TabOrdemServico_tosID" on "TabOrdemServico" tos (cost=0.28..0.50 rows=1 width=27) (actual time=0.002..0.002 rows=1 loops=3,420)

  • Index Cond: ("tosID" = trec."trectosID")
30. 6.840 6.840 ↑ 1.0 1 3,420

Index Scan using "TabPropostaComercial_tpcID" on "TabPropostaComercial" tpc (cost=0.28..1.03 rows=1 width=38) (actual time=0.002..0.002 rows=1 loops=3,420)

  • Index Cond: ("tpcID" = tos."tostpcID")
31. 6.840 6.840 ↑ 1.0 1 3,420

Index Scan using "TabFuncionario_tfuID" on "TabFuncionario" tfu (cost=0.27..0.30 rows=1 width=8) (actual time=0.001..0.002 rows=1 loops=3,420)

  • Index Cond: ("tfuID" = tpc."tpctfuID")
32. 6.840 6.840 ↑ 1.0 1 3,420

Index Scan using "TabPessoaID" on "TabPessoa" tpe_funcionario (cost=0.29..3.98 rows=1 width=24) (actual time=0.001..0.002 rows=1 loops=3,420)

  • Index Cond: ("tpeID" = tfu."tfutpeID")
33. 6.840 6.840 ↑ 1.0 1 3,420

Index Scan using "TabCliente_tclID" on "TabCliente" tcl (cost=0.28..0.34 rows=1 width=8) (actual time=0.002..0.002 rows=1 loops=3,420)

  • Index Cond: ("tclID" = trec."trectclID")
34. 27.360 27.360 ↓ 2.0 2 3,420

Index Scan using idx_trp_trecid_trpsubstituida on "TabReceitaParcela" trp (cost=0.29..2.03 rows=1 width=294) (actual time=0.006..0.008 rows=2 loops=3,420)

  • Index Cond: (("trptrecID" = trec."trecID") AND ("trpSubstituida" = false))
  • Filter: ((NOT "trpBaixada") AND (NOT "trpSubstituida") AND (NOT "trpPago") AND (NOT "trpEmitidoRemessa") AND ("trpIsExcluido" IS FALSE))
  • Rows Removed by Filter: 9
35. 19.950 20.037 ↓ 1.4 15 6,679

Materialize (cost=1.53..52.34 rows=11 width=416) (actual time=0.000..0.003 rows=15 loops=6,679)

36. 0.027 0.087 ↓ 1.4 15 1

Hash Right Join (cost=1.53..52.28 rows=11 width=416) (actual time=0.045..0.087 rows=15 loops=1)

  • Hash Cond: (tem."temID" = tcb."tcbtemID")
37. 0.008 0.034 ↑ 1.0 6 1

Nested Loop Left Join (cost=0.29..50.95 rows=6 width=44) (actual time=0.008..0.034 rows=6 loops=1)

38. 0.008 0.008 ↑ 1.0 6 1

Seq Scan on "TabEmpresa" tem (cost=0.00..1.06 rows=6 width=8) (actual time=0.004..0.008 rows=6 loops=1)

39. 0.018 0.018 ↑ 1.0 1 6

Index Scan using "TabPessoaID" on "TabPessoa" tpe_empresa (cost=0.29..8.30 rows=1 width=40) (actual time=0.003..0.003 rows=1 loops=6)

  • Index Cond: ("tpeID" = tem."temtpeID")
40. 0.012 0.026 ↓ 1.4 15 1

Hash (cost=1.11..1.11 rows=11 width=380) (actual time=0.026..0.026 rows=15 loops=1)

  • Buckets: 1024 Batches: 1 Memory Usage: 12kB
41. 0.014 0.014 ↓ 1.4 15 1

Seq Scan on "TabContaBancaria" tcb (cost=0.00..1.11 rows=11 width=380) (actual time=0.005..0.014 rows=15 loops=1)

42. 13.358 13.358 ↑ 1.0 1 6,679

Index Scan using "TabPessoaID" on "TabPessoa" tpe (cost=0.29..0.86 rows=1 width=42) (actual time=0.002..0.002 rows=1 loops=6,679)

  • Index Cond: ("tpeID" = tcl."tcltpeID")
43. 6.674 6.679 ↑ 1.0 2 6,679

Materialize (cost=0.00..1.03 rows=2 width=40) (actual time=0.000..0.001 rows=2 loops=6,679)

44. 0.005 0.005 ↑ 1.0 2 1

Seq Scan on "TabBancoCarteira" tbc (cost=0.00..1.02 rows=2 width=40) (actual time=0.004..0.005 rows=2 loops=1)

45. 6.675 6.679 ↑ 1.0 4 6,679

Materialize (cost=0.00..1.06 rows=4 width=8) (actual time=0.000..0.001 rows=4 loops=6,679)

46. 0.004 0.004 ↑ 1.0 4 1

Seq Scan on "TabBanco" tba (cost=0.00..1.04 rows=4 width=8) (actual time=0.003..0.004 rows=4 loops=1)

47. 0.000 0.000 ↓ 0.0 0 6,679

Index Scan using "TabTipoBaixa_ttbID" on "TabTipoBaixa" ttb (cost=0.14..0.16 rows=1 width=36) (actual time=0.000..0.000 rows=0 loops=6,679)

  • Index Cond: ("ttbID" = trp."trpTipoBaixa")
48. 0.000 0.000 ↓ 0.0 0 6,679

Index Scan using "TabRemessa_tremID" on "TabRemessa" trem (cost=0.28..0.31 rows=1 width=13) (actual time=0.000..0.000 rows=0 loops=6,679)

  • Index Cond: ("tremID" = trp."trptremID")
49. 0.102 0.223 ↓ 1.1 324 1

Hash (cost=7.05..7.05 rows=305 width=8) (actual time=0.223..0.223 rows=324 loops=1)

  • Buckets: 1024 Batches: 1 Memory Usage: 21kB
50. 0.121 0.121 ↓ 1.1 324 1

Seq Scan on "TabCicloFaturamentoOS" tcfos (cost=0.00..7.05 rows=305 width=8) (actual time=0.005..0.121 rows=324 loops=1)

51. 0.095 0.269 ↓ 1.0 313 1

Hash (cost=22.05..22.05 rows=305 width=26) (actual time=0.269..0.269 rows=313 loops=1)

  • Buckets: 1024 Batches: 1 Memory Usage: 26kB
52. 0.174 0.174 ↓ 1.0 313 1

Seq Scan on "TabCycleTransaction" tct (cost=0.00..22.05 rows=305 width=26) (actual time=0.004..0.174 rows=313 loops=1)

53.          

SubPlan (forSubquery Scan)

54. 0.200 0.200 ↑ 1.0 1 40

Result (cost=0.00..0.01 rows=1 width=32) (actual time=0.005..0.005 rows=1 loops=40)

55. 0.040 0.040 ↑ 1.0 1 40

Result (cost=0.00..0.01 rows=1 width=32) (actual time=0.001..0.001 rows=1 loops=40)

56. 0.040 0.040 ↑ 1.0 1 40

Result (cost=0.00..0.01 rows=1 width=32) (actual time=0.001..0.001 rows=1 loops=40)

57. 0.400 1.520 ↑ 1.0 1 40

Aggregate (cost=30.30..30.31 rows=1 width=8) (actual time=0.038..0.038 rows=1 loops=40)

58. 1.120 1.120 ↓ 2.2 22 40

Index Scan using idx_trp_trecid_trpsubstituida on "TabReceitaParcela" (cost=0.29..30.27 rows=10 width=4) (actual time=0.009..0.028 rows=22 loops=40)

  • Index Cond: (("trptrecID" = r."trecID") AND ("trpSubstituida" = false))
  • Filter: (("trpSubstituida" IS FALSE) AND ("trptrpOriundaID" IS NULL) AND (NOT "trpIsExcluido"))
  • Rows Removed by Filter: 0
59. 0.040 0.040 ↑ 1.0 1 40

Result (cost=0.00..0.01 rows=1 width=32) (actual time=0.001..0.001 rows=1 loops=40)

60. 0.200 120.640 ↑ 1.0 1 40

Aggregate (cost=256.98..256.99 rows=1 width=8) (actual time=3.016..3.016 rows=1 loops=40)

61. 120.440 120.440 ↑ 1.0 1 40

Seq Scan on "TabClienteContato" tcc (cost=0.00..256.98 rows=1 width=4) (actual time=0.918..3.011 rows=1 loops=40)

  • Filter: (("tccTipoContato" @> '{8}'::integer[]) AND ("tcctclID" = r."tclID"))
  • Rows Removed by Filter: 10721
62. 0.040 0.040 ↑ 1.0 1 40

Result (cost=0.00..0.01 rows=1 width=32) (actual time=0.001..0.001 rows=1 loops=40)

63. 0.320 0.320 ↑ 1.0 1 40

Result (cost=0.00..0.02 rows=1 width=32) (actual time=0.008..0.008 rows=1 loops=40)

64. 0.120 0.120 ↑ 1.0 1 40

Result (cost=0.00..0.02 rows=1 width=32) (actual time=0.003..0.003 rows=1 loops=40)

65. 0.080 0.280 ↑ 1.0 1 40

Aggregate (cost=13.65..13.66 rows=1 width=8) (actual time=0.007..0.007 rows=1 loops=40)

66. 0.200 0.200 ↓ 0.0 0 40

Index Scan using idx_tcdcli_tcdclitrpid on "TabClienteDocumento" (cost=0.29..13.64 rows=3 width=4) (actual time=0.005..0.005 rows=0 loops=40)

  • Index Cond: ("tcdclitrpID" = r."trpID")
67. 1.560 1.560 ↑ 1,000.0 1 40

Function Scan on proc_comercial_gettipospagamento (cost=0.25..10.25 rows=1,000 width=32) (actual time=0.039..0.039 rows=1 loops=40)

68. 0.080 2.200 ↓ 0.0 0 40

Limit (cost=0.29..15.15 rows=1 width=4) (actual time=0.055..0.055 rows=0 loops=40)

69. 0.120 2.120 ↓ 0.0 0 40

Nested Loop (cost=0.29..15.15 rows=1 width=4) (actual time=0.053..0.053 rows=0 loops=40)

  • Join Filter: (tcd."tcdDocumento" = tdc."tdcdocID")
70. 1.840 1.840 ↓ 2.0 2 40

Seq Scan on "TabDocumentoCliente" tdc (cost=0.00..1.48 rows=1 width=4) (actual time=0.008..0.046 rows=2 loops=40)

  • Filter: ("tdcdocValor" ~~* 'comprovante_pagamento%'::text)
  • Rows Removed by Filter: 36
71. 0.160 0.160 ↓ 0.0 0 80

Index Scan using idx_tcdcli_tcdclitrpid on "TabClienteDocumento" tcd (cost=0.29..13.64 rows=3 width=8) (actual time=0.002..0.002 rows=0 loops=80)

  • Index Cond: ("tcdclitrpID" = r."trpID")
72. 0.080 1.640 ↓ 0.0 0 40

Limit (cost=0.29..15.15 rows=1 width=4) (actual time=0.041..0.041 rows=0 loops=40)

73. 0.080 1.560 ↓ 0.0 0 40

Nested Loop (cost=0.29..15.15 rows=1 width=4) (actual time=0.039..0.039 rows=0 loops=40)

  • Join Filter: (tcd_1."tcdDocumento" = tdc_1."tdcdocID")
74. 1.400 1.400 ↓ 2.0 2 40

Seq Scan on "TabDocumentoCliente" tdc_1 (cost=0.00..1.48 rows=1 width=4) (actual time=0.031..0.035 rows=2 loops=40)

  • Filter: ("tdcdocValor" ~~* 'nfse%'::text)
  • Rows Removed by Filter: 36
75. 0.080 0.080 ↓ 0.0 0 80

Index Scan using idx_tcdcli_tcdclitrpid on "TabClienteDocumento" tcd_1 (cost=0.29..13.64 rows=3 width=8) (actual time=0.001..0.001 rows=0 loops=80)

  • Index Cond: ("tcdclitrpID" = r."trpID")
76. 2.080 2.080 ↑ 1.0 1 40

Function Scan on proc_common_countbusinessdays (cost=0.25..0.26 rows=1 width=8) (actual time=0.052..0.052 rows=1 loops=40)

77. 0.160 93.080 ↑ 1.0 1 40

Aggregate (cost=256.96..256.97 rows=1 width=8) (actual time=2.327..2.327 rows=1 loops=40)

78. 92.920 92.920 ↑ 1.0 1 40

Seq Scan on "TabEndereco" (cost=0.00..256.96 rows=1 width=4) (actual time=0.757..2.323 rows=1 loops=40)

  • Filter: (("tenTipoEndereco" @> '{1}'::integer[]) AND ("tentpeID" = r."tpeID"))
  • Rows Removed by Filter: 8254
79. 0.120 288.200 ↑ 1.0 1 40

Aggregate (cost=2,085.69..2,085.70 rows=1 width=8) (actual time=7.205..7.205 rows=1 loops=40)

80. 288.080 288.080 ↓ 0.0 0 40

Seq Scan on "TabReceitaParcelaContabil" (cost=0.00..2,085.68 rows=2 width=4) (actual time=7.020..7.202 rows=0 loops=40)

  • Filter: (("trpctrpID" = r."trpID") AND ("trpcTipo" = 1))
  • Rows Removed by Filter: 89212
81. 0.160 275.400 ↑ 1.0 1 40

Aggregate (cost=2,085.69..2,085.70 rows=1 width=8) (actual time=6.885..6.885 rows=1 loops=40)

82. 275.240 275.240 ↓ 0.0 0 40

Seq Scan on "TabReceitaParcelaContabil" "TabReceitaParcelaContabil_1" (cost=0.00..2,085.68 rows=2 width=4) (actual time=6.881..6.881 rows=0 loops=40)

  • Filter: (("trpctrpID" = r."trpID") AND ("trpcTipo" = 2))
  • Rows Removed by Filter: 89212
83. 22.120 22.120 ↑ 1,000.0 1 40

Function Scan on proc_common_getnetxbusinessdays (cost=0.25..10.25 rows=1,000 width=32) (actual time=0.552..0.553 rows=1 loops=40)

84. 0.120 33.440 ↑ 1.0 1 40

Aggregate (cost=203.78..203.79 rows=1 width=8) (actual time=0.836..0.836 rows=1 loops=40)

85. 0.157 33.320 ↑ 1.0 2 40

Nested Loop (cost=0.57..203.78 rows=2 width=4) (actual time=0.423..0.833 rows=2 loops=40)

86. 0.257 31.840 ↑ 1.0 1 40

Nested Loop (cost=0.28..173.41 rows=1 width=4) (actual time=0.267..0.796 rows=1 loops=40)

87. 31.240 31.240 ↑ 1.0 1 40

Seq Scan on "TabReceita" trec_1 (cost=0.00..165.10 rows=1 width=8) (actual time=0.254..0.781 rows=1 loops=40)

  • Filter: ("trectosID" = r."tosID")
  • Rows Removed by Filter: 6346
88. 0.343 0.343 ↑ 1.0 1 49

Index Only Scan using "TabOrdemServico_tosID" on "TabOrdemServico" tos_1 (cost=0.28..8.30 rows=1 width=4) (actual time=0.007..0.007 rows=1 loops=49)

  • Index Cond: ("tosID" = r."tosID")
  • Heap Fetches: 37
89. 1.323 1.323 ↑ 2.0 1 49

Index Scan using idx_trp_trecid_trpsubstituida on "TabReceitaParcela" trp_1 (cost=0.29..30.35 rows=2 width=8) (actual time=0.015..0.027 rows=1 loops=49)

  • Index Cond: (("trptrecID" = trec_1."trecID") AND ("trpSubstituida" = false))
  • Filter: (("trpPago" IS FALSE) AND ("trpBaixada" IS FALSE) AND ("trpSubstituida" IS FALSE) AND (('now'::cstring)::date > "trpDataVencimento"))
  • Rows Removed by Filter: 19
90. 2.720 2.720 ↑ 1,000.0 1 40

Function Scan on proc_comercial_getsituacoesordensservico (cost=0.25..10.25 rows=1,000 width=32) (actual time=0.068..0.068 rows=1 loops=40)