mam taki wykres:
Kod: Zaznacz cały
SELECT
lp=1,
k1.Knt_Akronim AS 'Akronim kontrahenta',
k1.Knt_Nazwa1 AS 'Nazwa kontrahenta',
CAST(sum(TrE_KsiegowaNetto) as varchar(20)) as 'Sprzedaż netto PLN',
CAST(sum(TrE_KosztKsiegowy) as varchar(20)) as KosztKsiegowy,
CAST(SUM(tre_ksiegowanetto)-sum(TrE_KosztKsiegowy) as varchar(20)) AS 'Marża',
CASE WHEN SUM(tre_ksiegowanetto) != 0 THEN
CASE WHEN sum(TrE_KosztKsiegowy) < SUM(tre_ksiegowanetto) THEN
str((round( (sum(tre_ksiegowanetto)-SUM(tre_kosztksiegowy))/SUM(tre_ksiegowanetto),2)*100), 3,0) + ' %'
ELSE '' END ELSE ''
END
AS 'Marża %',
case when k1.Knt_AkwTyp = 944 then (select concat(Prc_Nazwisko, ' ', Prc_Imie1) from cdn.PrcKarty where Prc_GIDNumer = k1.Knt_AkwNumer)
when k1.Knt_AkwTyp = 32 then k2.Knt_Akronim
else '' end as Akwizytor
FROM cdn.tranag n1
JOIN cdn.KntKarty k1 on k1.Knt_GIDNumer=n1.TrN_KntNumer
left join cdn.TraElem on n1.TrN_GIDTyp=TrE_GIDTyp AND n1.TrN_GIDNumer=TrE_GIDNumer
left JOIN cdn.TwrKarty ON Twr_GIDNumer=TrE_TwrNumer
left JOIN cdn.TwrGrupy ON Twr_GIDTyp=TwG_GIDTyp AND Twr_GIDNumer=TwG_GIDNumer
left JOIN cdn.KntKarty k2 on k2.Knt_GIDTyp=k1.Knt_AkwTyp and k2.Knt_GIDNumer=k1.Knt_AkwNumer
left join cdn.PrcKarty p1 on p1.Prc_GIDTyp=k1.Knt_AkwTyp and p1.Prc_GIDNumer=k1.Knt_AkwNumer
left join cdn.KntOpiekun on KtO_KntNumer=k1.Knt_GIDNumer and KtO_KntTyp=k1.Knt_GIDTyp
left join cdn.PrcKarty p2 on p2.Prc_GIDNumer=KtO_PrcNumer
WHERE
n1.trn_aktywny = 0
and n1.trn_trnlp = 127
and n1.trn_trntyp <> 12
and n1.trn_trntyp <> 13
and n1.TrN_GIDTyp in (2033,2041,2037,2045)
and n1.trn_spityp <> 0
and ((??okres = 1 and n1.TrN_TrNRok = ??rok)
or (??okres = 2 and n1.TrN_TrNRok = ??rok
and ((??kwartal = 1 and n1.TrN_TrNMiesiac in (1, 2, 3))
or (??kwartal = 2 and n1.TrN_TrNMiesiac in (4, 5, 6))
or (??kwartal = 3 and n1.TrN_TrNMiesiac in (7, 8, 9))
or (??kwartal = 4 and n1.TrN_TrNMiesiac in (10, 11, 12))))
or (??okres = 3 and n1.TrN_TrNRok = ??rok and n1.TrN_TrNMiesiac = ??miesiac)
or (??okres = 4 and n1.TrN_Data2 between ??dataOD and ??dataDO))
and n1.TrN_Stan >= 3
{choose (??Drzwi=0,' and 1=1 ', ' and n1.TrN_GIDNumer IN (SELECT distinct n3.TrN_GIDNumer from CDN.TraNag n3 left join cdn.TraSElem on TrS_GIDTyp=n1.TrN_GIDTyp and TrS_GIDNumer=n1.TrN_GIDNumer
left join cdn.Dostawy on Dst_GIDTyp=TrS_DstTyp and Dst_GIDNumer=TrS_DstNumer and Dst_GIDLp=TrS_DstLp
left join cdn.TraNag n2 on n2.TrN_GIDTyp=Dst_TrnTyp and n2.TrN_GIDNumer=Dst_TrnNumer WHERE n2.TrN_TrNSeria = ''PWD'' ) ') }
{choose (??Okna=0, ' and 1=1', ' and n1.TrN_GIDNumer IN (SELECT distinct n3.TrN_GIDNumer from CDN.TraNag n3 left join cdn.TraSElem on TrS_GIDTyp=n1.TrN_GIDTyp and TrS_GIDNumer=n1.TrN_GIDNumer
left join cdn.Dostawy on Dst_GIDTyp=TrS_DstTyp and Dst_GIDNumer=TrS_DstNumer and Dst_GIDLp=TrS_DstLp
left join cdn.TraNag n2 on n2.TrN_GIDTyp=Dst_TrnTyp and n2.TrN_GIDNumer=Dst_TrnNumer WHERE n2.TrN_TrNSeria = ''PBO'' ) ') }
{choose (??Uslugi=0, ' and 1=1', ' AND n1.TrN_GidNUmer IN (SELECT TrN_GIDNumer FROM CDN.TraNag
WHERE (
EXISTS (SELECT DISTINCT e2.Tre_GidNUmer from CDN.TraElem e2 WHERE e2.TrE_GidNumer = n1.Trn_GidNUmer and e2.TrE_TypTwr =4)
)
AND NOT EXISTS (
SELECT distinct n3.TRN_GIDNUMER FROM CDN.tranag n3 left join cdn.TraSElem ON TrS_GIDTyp=n1.TrN_GIDTyp and TrS_GIDNumer=n1.TrN_GIDNumer
left join cdn.Dostawy on Dst_GIDTyp=TrS_DstTyp AND Dst_GIDNumer=TrS_DstNumer and Dst_GIDLp=TrS_DstLp
left join cdn.TraNag n2 on n2.TrN_GIDTyp=Dst_TrnTyp and n2.TrN_GIDNumer=Dst_TrnNumer
WHERE n2.TrN_TrNSeria = ''PWD'' OR n2.TrN_TrNSeria = ''PBO'' )) ') }
{choose (??Towar=0, ' and 1=1', ' AND n1.TrN_GidNUmer IN (SELECT TrN_GIDNumer FROM CDN.TraNag
WHERE (
EXISTS (SELECT DISTINCT e2.Tre_GidNUmer from CDN.TraElem e2 WHERE e2.TrE_GidNumer = n1.Trn_GidNUmer and e2.TrE_TypTwr IN (1,2))
AND NOT EXISTS (SELECT DISTINCT e3.Tre_GidNUmer from CDN.TraElem e3 WHERE e3.TrE_GidNumer = n1.Trn_GidNUmer and e3.TrE_TypTwr =4)
)
AND NOT EXISTS (
SELECT distinct n3.TRN_GIDNUMER FROM CDN.tranag n3 left join cdn.TraSElem ON TrS_GIDTyp=n1.TrN_GIDTyp and TrS_GIDNumer=n1.TrN_GIDNumer
left join cdn.Dostawy on Dst_GIDTyp=TrS_DstTyp AND Dst_GIDNumer=TrS_DstNumer and Dst_GIDLp=TrS_DstLp
left join cdn.TraNag n2 on n2.TrN_GIDTyp=Dst_TrnTyp and n2.TrN_GIDNumer=Dst_TrnNumer
WHERE n2.TrN_TrNSeria = ''PWD'' OR n2.TrN_TrNSeria = ''PBO'' )) ') }
and (??wgAkwizytora = 0 or (??wgAkwizytora =1 and ((??akwTyp = 1 and k1.Knt_GIDNumer in (SELECT Knt_GIDNumer FROM cdn.KntKarty WHERE Knt_AkwNumer=??akwizytorPrac and Knt_AkwTyp = 944))
or (??akwTyp = 2 and k1.Knt_GIDNumer in (SELECT Knt_GIDNumer FROM cdn.KntKarty WHERE Knt_AkwNumer=??akwizytorKnt and Knt_AkwTyp = 32)))))
group by
k1.knt_akronim, k1.Knt_Nazwa1, k1.Knt_AkwTyp, k1.Knt_AkwNumer, k2.Knt_Akronim, p1.Prc_Nazwisko, p1.Prc_Imie1, p2.Prc_Nazwisko, p2.Prc_Imie1
@PAR ?@X|Drzwi|&Drzwi:REG=0 @? PAR@
@PAR ?@X|Okna|&Okna:REG=0 @? PAR@
@PAR ?@X|Uslugi|&Uslugi:REG=0 @? PAR@
@PAR ?@X|Towar|&Towar(Pozostałe):REG=0 @? PAR@
@PAR ?@O(Rok:1|Kwartał:2|Miesiąc:3|Zakres dat:4)|okres|Podsumowanie sprzedaży za:REG=1 @? @MSG(Wybrany okres raportowania) @TIP(Wybrany okres raportowania) PAR@
@PAR ?@R(select TrN_TrNRok as ID, TrN_TrNRok as Rok from cdn.TraNag
where
(TrN_GIDTyp in (2034, 2042) or
(TrN_GIDTyp in (2033, 2041) and TrN_SpiTyp in (2033, 2041) ) or
(TrN_GIDTyp in (2037, 2045) and TrN_SpiTyp in (2037, 2045) ) or
(TrN_GIDTyp in (2001, 2009, 2005, 2013) and TrN_SpiTyp <>0))
group by TrN_TrNRok)|rok|Rok:2021 @? @H(??okres = 4) @TIP(Wybierz rok) PAR@
@PAR ?@R(SELECT 1 AS Id, 'I kwartał' AS Kod UNION
SELECT 2, 'II kwartał' UNION
SELECT 3, 'III kwartał' UNION
SELECT 4, 'IV kwartał')|kwartal|Kwartał:REG=I kwartał @? @H(??okres <> 2) PAR@
@PAR ?@R(SELECT 1 AS Id, 'Styczeń' AS Kod UNION
SELECT 2, 'Luty' UNION
SELECT 3, 'Marzec' UNION
SELECT 4, 'Kwiecień' UNION
SELECT 5, 'Maj' UNION
SELECT 6, 'Czerwiec' UNION
SELECT 7, 'Lipiec' UNION
SELECT 8, 'Sierpień' UNION
SELECT 9, 'Wrzesień' UNION
SELECT 10, 'Październik' UNION
SELECT 11, 'Listopad' UNION
SELECT 12, 'Grudzień')|miesiac|Miesiąc:REG=Styczeń @? @H(??okres <> 3) PAR@
@PAR ?@D17|dataOD|Data od:REG=80358 @? @H(??okres <> 4) PAR@
@PAR ?@D17|dataDO|Data do:REG=80722 @? @H(??okres <> 4) PAR@
@PAR ?@X|wgAkwizytora|Wg akwizytora:REG=0 @? PAR@
@PAR ?@O(Z listy pracowników:1|Z listy kontrahentów:2)|akwTyp|Typ akwizytora:REG=1 @? @H(??wgAkwizytora = 0) PAR@
@PAR ?@LS20(SELECT Prc_gidnumer, CONCAT(Prc_nazwisko, ' ', Prc_Imie1) as Nazwa FROM cdn.Prckarty
WHERE Prc_GIDNumer in (select knt_AkwNumer from cdn.KntKarty where (Knt_AkwNumer <> 0 and Knt_AkwTyp = 944))
order by Nazwa asc|GENERICLOOKUP(Akwizytorzy z listy pracowników, 0, 1))|akwizytorPrac|Akwizytor:REG=JAROSZUK MAREK @? @H({(??wgAkwizytora = 0) or (??akwTyp = 2)}) PAR@
@PAR ?@LS20(SELECT knt_gidnumer, knt_akronim AS Nazwa FROM cdn.kntkarty
WHERE Knt_GIDNumer in (select knt_AkwNumer from cdn.KntKarty where (Knt_AkwNumer <> 0 and Knt_AkwTyp = 32))
order by Nazwa asc|GENERICLOOKUP(Akwizytorzy z listy kontrahentów, 0, 1))|akwizytorKnt|Akwizytor:REG=WIN-UP OPOLSKI @? @H((??wgAkwizytora = 0) or (??akwTyp = 1)) PAR@