-- ============================================= -- Author: -- Create date: -- Description: -- ============================================= --[C6MartPeriodico].[PL_DT_S163PatrimonioFinanziarioMAssetClass] 'F', 'BRCRRT70L21A390C' CREATE procedure [C6MartPeriodico].[PL_D_S163PatrimonioFinanziarioMAssetClass] -- Add the parameters for the stored procedure here -- Add the parameters for the stored procedure here @Rete char(1), @CodiceFiscale varchar(16) AS BEGIN SELECT DISTINCT ASSETCLASS.ORDINAMENTO AS Ordinamento, VALORIASSET.ID_ASSETCLASS AS AssetClassId, ASSETCLASS.DESCRIZIONE AS AssetClassName, cast(SUM(VALORIASSET.CONTROVALORE) OVER (PARTITION BY VALORIASSET.ID_ASSETCLASS) as decimal(19,6)) AS Controvalore, isnull(( SUM(VALORIASSET.CONTROVALORE) OVER (PARTITION BY VALORIASSET.ID_ASSETCLASS) / NULLIF(SUM(VALORIASSET.CONTROVALORE) OVER (PARTITION BY 'TOTALE'),0) ) * 100,0) AS Percentuale, cast (SUM(VALORIASSET.CONTROVALORE) OVER (PARTITION BY 'TOTALE') as decimal(19,6)) AS PatrimonioFinanziarioCTV FROM ( --PRODOTTI TERZI A CATALOGO SELECT ISNULL(ASSETPERC.ID_ASSETCLASS,'AL') AS ID_ASSETCLASS, PATRTERZI.CTV * ISNULL(ASSETPERC.PERC,1) AS Controvalore FROM C6MartPeriodico.PATRIMONIO_TERZI PATRTERZI LEFT OUTER JOIN C6MartPeriodico.ASSET_PERC ASSETPERC ON PATRTERZI.COD_PRODOTTO = ASSETPERC.COD_PRODOTTO AND ASSETPERC.LIVELLO = 1 WHERE 1 = 1 AND PATRTERZI.COD_PRODOTTO <> 'PRODOTTO NON IN CATALOGO' AND PATRTERZI.RETE = @Rete AND PATRTERZI.COD_FISCALE = @CodiceFiscale UNION ALL --PRODOTTI TERZI NON A CATALOGO SELECT ISNULL(ASSETPERC.ID_ASSETCLASS,'AL') AS ID_ASSETCLASS, PATRTERZI.CTV*ISNULL(ASSETPERC.PERC,1) AS Controvalore FROM C6MartPeriodico.PATRIMONIO_TERZI PATRTERZI LEFT OUTER JOIN C6MartPeriodico.ASSET_PERC_TERZI ASSETPERC ON PATRTERZI.COD_PRODOTTO_TERZI = ASSETPERC.COD_PRODOTTO_TERZI AND ASSETPERC.LIVELLO = 1 WHERE 1 = 1 AND PATRTERZI.COD_PRODOTTO = 'PRODOTTO NON IN CATALOGO' AND PATRTERZI.RETE = @Rete AND PATRTERZI.COD_FISCALE = @CodiceFiscale ) VALORIASSET INNER JOIN C6MartPeriodico.ASSETCLASS ASSETCLASS ON ASSETCLASS.ID_ASSETCLASS = VALORIASSET.ID_ASSETCLASS ORDER BY ASSETCLASS.ORDINAMENTO END