Search code examples
postgresqlvariablessubquery

How to move variables from subquery to an outer query - postgres?


I am writing query below and as you can see it has a lot of subqueries. I would like to throw out from subquery to outer query "dolzniki_terjatve.datum_vlozitve" and "dolzniki_terjatve.glavnica", so that I don't need to change them every time. I have tried many solutions which I have found here but nothing seems to work. Any guess?

select distinct on (upniki.naziv)
upniki.naziv, 
b.stevilo,  
b.glavnica_skupaj/b.stevilo as povprecna_glavnica, 
b.glavnica_skupaj,
coalesce(taksa_vlozitve,0)+coalesce(dodatna_taksa,0) as celotna_sodna_taksa,
coalesce(stroski,0)-coalesce(taksa_vlozitve,0)+ coalesce(dodatni_odvetniski,0)as vsi_odvetniski_stroski,
coalesce(stroski_izvrsitelja,0) as stroski_izvrsitelja,
coalesce(pravdni,0) as pravdni,
coalesce(glavnicapok,0)+coalesce(glavnicapokobresti,0) as pokrivanje_glavice_z_obrestmi,
coalesce(poksodnataksavlozitve,0)+coalesce(poksodnataksavlozitveobresti,0)+coalesce(pokdodatnasodnataksa,0)+coalesce(pokdodatnasodnataksaobresti,0) as pokrivanje_takse_z_obrestmi,
coalesce(pokodvstroskivlozitve,0)+coalesce(pokodvstroskivlozitveobresti,0)+coalesce(pokdodatniodvstroski,0)+coalesce(pokdodatniodvstroskiobresti,0) as pokrivanje_odvetniskih_z_obrestmi,
coalesce(pokstroskiizvrsitelja,0)+coalesce(pokstroskiizvrsiteljaobresti,0) as pokrivanje_stroskov_izvrsitelja_z_obrestmi,
coalesce(pokpravdnistroski,0)+coalesce(pokpravdnistroskiobresti,0) as pokrivanje_pravdnih_z_obrestmi,
((coalesce(glavnicapok,0)+coalesce(glavnicapokobresti,0))/b.glavnica_skupaj) as uspesnosti_glavnice,
((coalesce(poksodnataksavlozitve,0)+coalesce(poksodnataksavlozitveobresti,0)+coalesce(pokdodatnasodnataksa,0)+coalesce(pokdodatnasodnataksaobresti,0))/(coalesce(taksa_vlozitve,0)+coalesce(dodatna_taksa,1))) as uspesnosti_taks,
((coalesce(pokodvstroskivlozitve,0)+coalesce(pokodvstroskivlozitveobresti,0)+coalesce(pokdodatniodvstroski,0)+coalesce(pokdodatniodvstroskiobresti,0))/(coalesce(stroski,0)-coalesce(taksa_vlozitve,0)+coalesce(dodatni_odvetniski,1))) as uspesnosti_odvetniskih_stroskov,
((coalesce(pokstroskiizvrsitelja,0)+coalesce(pokstroskiizvrsiteljaobresti,0))/coalesce(stroski_izvrsitelja,1)) as uspesnosti_stroskov_izvrsitelja,
((coalesce(pokpravdnistroski,0)+coalesce(pokpravdnistroskiobresti,0))/coalesce(pravdni,1)) as uspesnosti_pravdni,
coalesce(a.pokrivanje,0) as pokrivanje_glavnice_z_vsemi_placili,
(coalesce(a.pokrivanje,0)/b.glavnica_skupaj) as procent,
coalesce(taksa_vlozitve,0) as taksa_vlozitve,
coalesce(stroski,0)-coalesce(taksa_vlozitve) as odv_stroski_vlozitve,
coalesce(dodatna_taksa,0) as dodatna_taksa,
coalesce(dodatni_odvetniski,0) as dodatni_odvetniski,
coalesce(stroski_izvrsitelja,0)as stroski_izvrsitelja,
coalesce(pravdni,0) as pravdni_stroski,
coalesce(glavnicapok,0) as glavnicapok,
coalesce(glavnicapokobresti,0) as glavnicapokobresti,
coalesce (poksodnataksavlozitve,0) as poksodnataksavlozitve,
coalesce(poksodnataksavlozitveobresti) as poksodnataksavlozitveobresti,
coalesce (pokodvstroskivlozitve,0) as pokodvstroskivlozitve,
coalesce(pokodvstroskivlozitveobresti,0) as pokoodvstroskivlozitveobresti,
coalesce(pokdodatnasodnataksa,0) as pokdodatnasodnataksa,
coalesce(pokdodatnasodnataksaobresti,0) as pokdodatnasodnataksaobresti,
coalesce(pokdodatniodvstroski,0) as pokdodatniodvstroski,
coalesce(pokdodatniodvstroskiobresti,0) as pokdodatniodvstroskiobresti,
coalesce(pokstroskiizvrsitelja,0) as pokstroskiizvrsitelja,
coalesce(pokstroskiizvrsiteljaobresti,0) as pokstroskiizvrsiteljaobresti,
coalesce(pokpravdnistroski,0) as pokpravdnistroski,
coalesce(pokpravdnistroskiobresti,0) as pokpravdnistroskiobresti
from dolzniki_terjatve
inner join paketi on dolzniki_terjatve.id_paket=paketi.id_paket
inner join upniki on paketi.id_upnik=upniki.id_upnik
left join (select paketi.id_upnik, coalesce(sum(znesek),0)-coalesce(sum(preplacilo),0) as pokrivanje
           from specifikacije1, dolzniki_terjatve, paketi
           where specifikacije1.referenca=dolzniki_terjatve.referenca and dolzniki_terjatve.id_paket=paketi.id_paket
           and datumplacila <=date(dolzniki_terjatve.datum_vlozitve) + interval '7 month' 
           and dolzniki_terjatve.datum_vlozitve >='2018-06-01' and dolzniki_terjatve.datum_vlozitve < '2019-01-01' 
           and dolzniki_terjatve.glavnica > 0 and dolzniki_terjatve.glavnica < 500 
           group by paketi.id_upnik) as a on paketi.id_upnik=a.id_upnik
left join (select paketi.id_upnik, count(referenca) as stevilo, sum(glavnica) as glavnica_skupaj, coalesce(sum(stroski_vlozitve),0) as stroski, coalesce(sum(sodna_taksa_vlozitve),1) as taksa_vlozitve 
           from dolzniki_terjatve, paketi
           where dolzniki_terjatve.id_paket=paketi.id_paket 
           and dolzniki_terjatve.datum_vlozitve >='2018-06-01' and dolzniki_terjatve.datum_vlozitve < '2019-01-01' 
           and dolzniki_terjatve.glavnica > 0 and dolzniki_terjatve.glavnica < 500  
           group by paketi.id_upnik) 
           as b on paketi.id_upnik=b.id_upnik
left join (select paketi.id_upnik, sum(znesek) as dodatna_taksa 
           from dolzniki_dodatni_stroski, dolzniki_terjatve, paketi 
           where dolzniki_terjatve.referenca=dolzniki_dodatni_stroski.referenca and dolzniki_terjatve.id_paket=paketi.id_paket 
           and tip_stroskov='1' 
           and dolzniki_terjatve.glavnica > 0 and dolzniki_terjatve.glavnica < 500
           and dolzniki_terjatve.datum_vlozitve >='2018-06-01' and dolzniki_terjatve.datum_vlozitve < '2019-01-01'         
           and datum <= date(dolzniki_terjatve.datum_vlozitve) + interval '7 month' 
           group by paketi.id_upnik)
           as tabledodatnataksa on paketi.id_upnik=tabledodatnataksa.id_upnik
left join (select paketi.id_upnik, sum(znesek) as dodatni_odvetniski 
           from dolzniki_dodatni_stroski, dolzniki_terjatve, paketi 
           where dolzniki_terjatve.referenca=dolzniki_dodatni_stroski.referenca and dolzniki_terjatve.id_paket=paketi.id_paket
           and tip_stroskov='2' 
           and dolzniki_terjatve.glavnica > 0 and dolzniki_terjatve.glavnica < 500
           and dolzniki_terjatve.datum_vlozitve >='2018-06-01' and dolzniki_terjatve.datum_vlozitve < '2019-01-01' and 
           datum <= date(dolzniki_terjatve.datum_vlozitve) + interval '7 month' 
           group by paketi.id_upnik)
           as tabledodatniodv on paketi.id_upnik=tabledodatniodv.id_upnik
left join (select paketi.id_upnik, coalesce(sum(znesek),0) as stroski_izvrsitelja 
           from dolzniki_dodatni_stroski, dolzniki_terjatve, paketi 
           where dolzniki_terjatve.referenca=dolzniki_dodatni_stroski.referenca and dolzniki_terjatve.id_paket=paketi.id_paket
           and tip_stroskov='3'
           and dolzniki_terjatve.glavnica > 0 and dolzniki_terjatve.glavnica < 500 
           and dolzniki_terjatve.datum_vlozitve >='2018-06-01' and dolzniki_terjatve.datum_vlozitve < '2019-01-01' 
           and datum <= date(dolzniki_terjatve.datum_vlozitve) + interval '7 month' 
           group by paketi.id_upnik)
           as tablestroskiizv on paketi.id_upnik=tablestroskiizv.id_upnik
left join (select paketi.id_upnik, sum(znesek) as pravdni 
           from dolzniki_dodatni_stroski, dolzniki_terjatve, paketi 
           where dolzniki_terjatve.referenca=dolzniki_dodatni_stroski.referenca and dolzniki_terjatve.id_paket=paketi.id_paket
           and tip_stroskov='4'
           and dolzniki_terjatve.glavnica > 0 and dolzniki_terjatve.glavnica < 500 
           and dolzniki_terjatve.datum_vlozitve >='2018-06-01' and dolzniki_terjatve.datum_vlozitve < '2019-06-01'
           and datum <= date(dolzniki_terjatve.datum_vlozitve) + interval '7 month'
           group by paketi.id_upnik) as tablepravdni on paketi.id_upnik=tablepravdni.id_upnik
left join (select paketi.id_upnik, sum(specifikacije_postavke.placilo) as glavnicapok 
           from specifikacije_postavke, specifikacije1, dolzniki_terjatve, paketi
           where specifikacije1.idizracun=specifikacije_postavke.idizracun and dolzniki_terjatve.referenca=specifikacije1.referenca and paketi.id_paket=dolzniki_terjatve.id_paket
           and postavka='1' and obresti=false
           and dolzniki_terjatve.glavnica > 0 and dolzniki_terjatve.glavnica < 500 
           and dolzniki_terjatve.datum_vlozitve >='2018-06-01' and dolzniki_terjatve.datum_vlozitve < '2019-01-01'
           and datumplacila <= date(dolzniki_terjatve.datum_vlozitve) + interval '7 month' 
           group by paketi.id_upnik)
           as tabelaglavnice on paketi.id_upnik=tabelaglavnice.id_upnik
left join (select paketi.id_upnik, sum(specifikacije_postavke.placilo) as glavnicapokobresti 
           from specifikacije_postavke, specifikacije1, dolzniki_terjatve, paketi
           where specifikacije1.idizracun=specifikacije_postavke.idizracun and dolzniki_terjatve.referenca=specifikacije1.referenca and paketi.id_paket=dolzniki_terjatve.id_paket
           and postavka='1' and obresti=true
           and dolzniki_terjatve.glavnica > 0 and dolzniki_terjatve.glavnica < 500 
           and dolzniki_terjatve.datum_vlozitve >='2018-06-01' and dolzniki_terjatve.datum_vlozitve < '2019-01-01'
           and datumplacila <= date(dolzniki_terjatve.datum_vlozitve) + interval '7 month' 
           group by paketi.id_upnik)
           as tabelaglavniceobresti on paketi.id_upnik=tabelaglavniceobresti.id_upnik
left join (select paketi.id_upnik, sum(specifikacije_postavke.placilo) as pokodvstroskivlozitve 
           from specifikacije_postavke, specifikacije1, dolzniki_terjatve, paketi
           where specifikacije1.idizracun=specifikacije_postavke.idizracun and dolzniki_terjatve.referenca=specifikacije1.referenca and paketi.id_paket=dolzniki_terjatve.id_paket
           and postavka='2' and obresti=false
           and dolzniki_terjatve.glavnica > 0 and dolzniki_terjatve.glavnica < 500 
           and dolzniki_terjatve.datum_vlozitve >='2018-06-01' and dolzniki_terjatve.datum_vlozitve < '2019-01-01'
           and datumplacila <= date(dolzniki_terjatve.datum_vlozitve) + interval '7 month' 
           group by paketi.id_upnik)
           as tabelaodvstroski on paketi.id_upnik=tabelaodvstroski.id_upnik
left join (select paketi.id_upnik, sum(specifikacije_postavke.placilo) as pokodvstroskivlozitveobresti 
           from specifikacije_postavke, specifikacije1, dolzniki_terjatve, paketi
           where specifikacije1.idizracun=specifikacije_postavke.idizracun and dolzniki_terjatve.referenca=specifikacije1.referenca and paketi.id_paket=dolzniki_terjatve.id_paket
           and postavka='2' and obresti=true
           and dolzniki_terjatve.glavnica > 0 and dolzniki_terjatve.glavnica < 500 
           and dolzniki_terjatve.datum_vlozitve >='2018-06-01' and dolzniki_terjatve.datum_vlozitve < '2019-01-01'
           and datumplacila <= date(dolzniki_terjatve.datum_vlozitve) + interval '7 month' 
           group by paketi.id_upnik)
           as tabelaodvstroskiobresti on paketi.id_upnik=tabelaodvstroskiobresti.id_upnik
left join (select paketi.id_upnik, sum(specifikacije_postavke.placilo) as poksodnataksavlozitve 
           from specifikacije_postavke, specifikacije1, dolzniki_terjatve, paketi
           where specifikacije1.idizracun=specifikacije_postavke.idizracun and dolzniki_terjatve.referenca=specifikacije1.referenca and paketi.id_paket=dolzniki_terjatve.id_paket
           and postavka='3' and obresti=false
           and dolzniki_terjatve.glavnica > 0 and dolzniki_terjatve.glavnica < 500 
           and dolzniki_terjatve.datum_vlozitve >='2018-06-01' and dolzniki_terjatve.datum_vlozitve < '2019-01-01'
           and datumplacila <= date(dolzniki_terjatve.datum_vlozitve) + interval '7 month' 
           group by paketi.id_upnik)
           as tabelasodnataksavlozitve on paketi.id_upnik=tabelasodnataksavlozitve.id_upnik
left join (select paketi.id_upnik, sum(specifikacije_postavke.placilo) as poksodnataksavlozitveobresti 
           from specifikacije_postavke, specifikacije1, dolzniki_terjatve, paketi
           where specifikacije1.idizracun=specifikacije_postavke.idizracun and dolzniki_terjatve.referenca=specifikacije1.referenca and paketi.id_paket=dolzniki_terjatve.id_paket
           and postavka='3' and obresti=true
           and dolzniki_terjatve.glavnica > 0 and dolzniki_terjatve.glavnica < 500 
           and dolzniki_terjatve.datum_vlozitve >='2018-06-01' and dolzniki_terjatve.datum_vlozitve < '2019-01-01'
           and datumplacila <= date(dolzniki_terjatve.datum_vlozitve) + interval '7 month' 
           group by paketi.id_upnik)
           as tabelasodnataksavlozitveobresti on paketi.id_upnik=tabelasodnataksavlozitveobresti.id_upnik
left join (select paketi.id_upnik, sum(specifikacije_postavke.placilo) as pokdodatnasodnataksa
           from specifikacije_postavke, specifikacije1, dolzniki_terjatve, paketi
           where specifikacije1.idizracun=specifikacije_postavke.idizracun and dolzniki_terjatve.referenca=specifikacije1.referenca and paketi.id_paket=dolzniki_terjatve.id_paket
           and postavkastroski='1' and obresti=false
           and dolzniki_terjatve.glavnica > 0 and dolzniki_terjatve.glavnica < 500 
           and dolzniki_terjatve.datum_vlozitve >='2018-06-01' and dolzniki_terjatve.datum_vlozitve < '2019-01-01'
           and datumplacila <= date(dolzniki_terjatve.datum_vlozitve) + interval '7 month' 
           group by paketi.id_upnik)
           as tabeladodatnasodnataksa on paketi.id_upnik=tabeladodatnasodnataksa.id_upnik
left join (select paketi.id_upnik, sum(specifikacije_postavke.placilo) as pokdodatnasodnataksaobresti
           from specifikacije_postavke, specifikacije1, dolzniki_terjatve, paketi
           where specifikacije1.idizracun=specifikacije_postavke.idizracun and dolzniki_terjatve.referenca=specifikacije1.referenca and paketi.id_paket=dolzniki_terjatve.id_paket
           and postavkastroski='1' and obresti=true
           and dolzniki_terjatve.glavnica > 0 and dolzniki_terjatve.glavnica < 500 
           and dolzniki_terjatve.datum_vlozitve >='2018-06-01' and dolzniki_terjatve.datum_vlozitve < '2019-01-01'
           and datumplacila <= date(dolzniki_terjatve.datum_vlozitve) + interval '7 month' 
           group by paketi.id_upnik)
           as tabeladodatnasodnataksaobresti on paketi.id_upnik=tabeladodatnasodnataksaobresti.id_upnik
left join (select paketi.id_upnik, sum(specifikacije_postavke.placilo) as pokdodatniodvstroski
           from specifikacije_postavke, specifikacije1, dolzniki_terjatve, paketi
           where specifikacije1.idizracun=specifikacije_postavke.idizracun and dolzniki_terjatve.referenca=specifikacije1.referenca and paketi.id_paket=dolzniki_terjatve.id_paket
           and postavkastroski='2' and obresti=false
           and dolzniki_terjatve.glavnica > 0 and dolzniki_terjatve.glavnica < 500 
           and dolzniki_terjatve.datum_vlozitve >='2018-06-01' and dolzniki_terjatve.datum_vlozitve < '2019-01-01'
           and datumplacila <= date(dolzniki_terjatve.datum_vlozitve) + interval '7 month' 
           group by paketi.id_upnik)
           as tabeladodatniodvstroski on paketi.id_upnik=tabeladodatniodvstroski.id_upnik
left join (select paketi.id_upnik, sum(specifikacije_postavke.placilo) as pokdodatniodvstroskiobresti
           from specifikacije_postavke, specifikacije1, dolzniki_terjatve, paketi
           where specifikacije1.idizracun=specifikacije_postavke.idizracun and dolzniki_terjatve.referenca=specifikacije1.referenca and paketi.id_paket=dolzniki_terjatve.id_paket
           and postavkastroski='2' and obresti=true
           and dolzniki_terjatve.glavnica > 0 and dolzniki_terjatve.glavnica < 500 
           and dolzniki_terjatve.datum_vlozitve >='2018-06-01' and dolzniki_terjatve.datum_vlozitve < '2019-01-01'
           and datumplacila <= date(dolzniki_terjatve.datum_vlozitve) + interval '7 month' 
           group by paketi.id_upnik)
           as tabeladodatniodvstroskiobresti on paketi.id_upnik=tabeladodatniodvstroskiobresti.id_upnik
left join (select paketi.id_upnik, sum(specifikacije_postavke.placilo) as pokstroskiizvrsitelja
           from specifikacije_postavke, specifikacije1, dolzniki_terjatve, paketi
           where specifikacije1.idizracun=specifikacije_postavke.idizracun and dolzniki_terjatve.referenca=specifikacije1.referenca and paketi.id_paket=dolzniki_terjatve.id_paket
           and postavkastroski='3' and obresti=false
           and dolzniki_terjatve.glavnica > 0 and dolzniki_terjatve.glavnica < 500 
           and dolzniki_terjatve.datum_vlozitve >='2018-06-01' and dolzniki_terjatve.datum_vlozitve < '2019-01-01'
           and datumplacila <= date(dolzniki_terjatve.datum_vlozitve) + interval '7 month' 
           group by paketi.id_upnik)
           as tabelastroskiizvrsitelja on paketi.id_upnik=tabelastroskiizvrsitelja.id_upnik
left join (select paketi.id_upnik, sum(specifikacije_postavke.placilo) as pokstroskiizvrsiteljaobresti
           from specifikacije_postavke, specifikacije1, dolzniki_terjatve, paketi
           where specifikacije1.idizracun=specifikacije_postavke.idizracun and dolzniki_terjatve.referenca=specifikacije1.referenca and paketi.id_paket=dolzniki_terjatve.id_paket
           and postavkastroski='3' and obresti=true
           and dolzniki_terjatve.glavnica > 0 and dolzniki_terjatve.glavnica < 500 
           and dolzniki_terjatve.datum_vlozitve >='2018-06-01' and dolzniki_terjatve.datum_vlozitve < '2019-01-01'
           and datumplacila <= date(dolzniki_terjatve.datum_vlozitve) + interval '7 month' 
           group by paketi.id_upnik)
           as tabelastroskiizvrsiteljaobresti on paketi.id_upnik=tabelastroskiizvrsiteljaobresti.id_upnik
left join (select paketi.id_upnik, sum(specifikacije_postavke.placilo) as pokpravdnistroski
           from specifikacije_postavke, specifikacije1, dolzniki_terjatve, paketi
           where specifikacije1.idizracun=specifikacije_postavke.idizracun and dolzniki_terjatve.referenca=specifikacije1.referenca and paketi.id_paket=dolzniki_terjatve.id_paket
           and postavkastroski='4' and obresti=false
           and dolzniki_terjatve.glavnica > 0 and dolzniki_terjatve.glavnica < 500 
           and dolzniki_terjatve.datum_vlozitve >='2018-06-01' and dolzniki_terjatve.datum_vlozitve < '2019-01-01'
           and datumplacila <= date(dolzniki_terjatve.datum_vlozitve) + interval '7 month' 
           group by paketi.id_upnik)
           as tabelapravdnistroski on paketi.id_upnik=tabelapravdnistroski.id_upnik
left join (select paketi.id_upnik, sum(specifikacije_postavke.placilo) as pokpravdnistroskiobresti
           from specifikacije_postavke, specifikacije1, dolzniki_terjatve, paketi
           where specifikacije1.idizracun=specifikacije_postavke.idizracun and dolzniki_terjatve.referenca=specifikacije1.referenca and paketi.id_paket=dolzniki_terjatve.id_paket
           and postavkastroski='4' and obresti=true
           and dolzniki_terjatve.glavnica > 0 and dolzniki_terjatve.glavnica < 500 
           and dolzniki_terjatve.datum_vlozitve >='2018-06-01' and dolzniki_terjatve.datum_vlozitve < '2019-01-01'
           and datumplacila <= date(dolzniki_terjatve.datum_vlozitve) + interval '7 month' 
           group by paketi.id_upnik)
           as tabelapravdnistroskiobresti on paketi.id_upnik=tabelapravdnistroskiobresti.id_upnik
where upniki.id_upnik in (131,141,1009, 1000)

Solution

  • We can define params in WITH section and use them in subqueries

    Simple example

    with 
      params as (select 1 param_from, 1 param_to)
    select header_id, count(*) from position, params
    where position.header_id between param_from and param_to
    group by header_id
    
    

    DB Fiddle to play with

    Query after refactor

    with 
      params as (select '2018-06-01'::timestamp p_datum_vlozitve_from, '2019-01-01'::timestamp  p_datum_vlozitve_to)
    select distinct on (upniki.naziv)
    upniki.naziv, 
    b.stevilo, 
    .......  original query  .....
    

    And instead of constans, values from param query can be used.

    For example in tabledodatnataksa subquery

    select paketi.id_upnik, sum(znesek) as dodatna_taksa 
               from dolzniki_dodatni_stroski, dolzniki_terjatve, paketi 
               where dolzniki_terjatve.referenca=dolzniki_dodatni_stroski.referenca and dolzniki_terjatve.id_paket=paketi.id_paket 
               and tip_stroskov='1' 
               and dolzniki_terjatve.glavnica > 0 and dolzniki_terjatve.glavnica < 500
               and dolzniki_terjatve.datum_vlozitve >='2018-06-01' and dolzniki_terjatve.datum_vlozitve < '2019-01-01'         
               and datum <= date(dolzniki_terjatve.datum_vlozitve) + interval '7 month' 
               group by paketi.id_upnik
    

    add param to tables and use p_datum_vlozitve_from instead of 2018-06-01 and p_datum_vlozitve_to instead of 2019-01-01

    select paketi.id_upnik, sum(znesek) as dodatna_taksa 
               from dolzniki_dodatni_stroski, dolzniki_terjatve, paketi, param 
               where dolzniki_terjatve.referenca=dolzniki_dodatni_stroski.referenca and dolzniki_terjatve.id_paket=paketi.id_paket 
               and tip_stroskov='1' 
               and dolzniki_terjatve.glavnica > 0 and dolzniki_terjatve.glavnica < 500
               and dolzniki_terjatve.datum_vlozitve >=p_datum_vlozitve_from and dolzniki_terjatve.datum_vlozitve < p_datum_vlozitve_to         
               and datum <= date(dolzniki_terjatve.datum_vlozitve) + interval '7 month' 
               group by paketi.id_upnik
    

    Just small note

    In JOIN subqueries there is a lot of repetitive code.. for example tabledodatnataksa,tabledodatniodv,tablestroskiizv,tablepravdni can be easily refactor to one subquery

    select paketi.id_upnik, 
           sum(znesek) filter(where tip_stroskov='1') as dodatna_taksa, 
           sum(znesek) filter(where tip_stroskov='2') as dodatni_odvetniski, 
           coalesce(sum(znesek) filter(where tip_stroskov='3'),0) as stroski_izvrsitelja, 
           sum(znesek) filter(where tip_stroskov='4') as pravdni 
    from dolzniki_dodatni_stroski, dolzniki_terjatve, paketi 
        where dolzniki_terjatve.referenca=dolzniki_dodatni_stroski.referenca and dolzniki_terjatve.id_paket=paketi.id_paket 
              and dolzniki_terjatve.glavnica > 0 and dolzniki_terjatve.glavnica < 500
              and dolzniki_terjatve.datum_vlozitve >='2018-06-01' and dolzniki_terjatve.datum_vlozitve < '2019-01-01'         
              and datum <= date(dolzniki_terjatve.datum_vlozitve) + interval '7 month' 
              group by paketi.id_upnik