CREATE procedure [C6MartPeriodico].[DM_PATRIMONIO_BF] AS BEGIN -- riportare le logiche nelle rispettive sp di PL SET NOCOUNT ON; DECLARE @ID_ELAB INT DECLARE @TIPO_ELAB VARCHAR(1) SET @ID_ELAB = C6MartPeriodico.GETIDELAB() SET @TIPO_ELAB = C6MartPeriodico.GETTIPOELAB() -- Log esecuzione INSERT INTO LOG_ESECUZIONE (Nome, Inizio, Nota) VALUES ( 'DM_PATRIMONIO_BF', GETDATE(), 'Elaborazione trimestrale' ) TRUNCATE TABLE C6MartPeriodico.PATRIMONIO_BF SELECT CONTRATTOSINTESI.RETE AS RETE, CONTRATTOSINTESI.CODFIS AS COD_FISCALE, CONTRATTOSINTESI.POSITIONID AS POSITIONID, SUBSTRING(CONTRATTOSINTESI.POSITIONID,1,57) AS COD_PRODOTTO, CONTRATTOSINTESI.CODCONF AS ID_CONTRATTO, CASE WHEN ISDATE(CONTRATTOSINTESI.DTSOTTOS) = 0 THEN NULL ELSE CAST(CAST(CONTRATTOSINTESI.DTSOTTOS AS VARCHAR(8)) AS DATETIME) END AS DATA_SOTTOSCRIZIONE, NULL AS COD_STATO, --CONTRATTOSINTESI.CODICESTATO AS COD_STATO, CONTRATTOSINTESI.NUMPOL AS NUM_POLIZZA, CONTRATTOSINTESI.MAF AS COD_MAF, CONTRATTOSINTESI.CODINT AS COD_INTERNO, CONTRATTOSINTESI.SUBPROD AS COD_SOTTOPRODOTTO, CONTRATTOSINTESI.TIPPROD AS TIPO_PRODOTTO, CASE WHEN CONSAREA.C_NEEDAREA_V_46360 = 'Inv' AND PRCONSUL.C_PROJECTNAM_11D1A IS NULL THEN 'Prodotti non associati a progetti' ELSE LTRIM(RTRIM(PRCONSUL.C_PROJECTNAM_11D1A)) END AS NOME_PROGETTO, PRCONSUL.TYPE$_PROJEC_14674 AS TIPO_PROGETTO, CONSAREA.C_NEEDAREA_V_46360 AS ID_AREA, CASE WHEN ISDATE(CONTRATTOSINTESI.DTRIFE) = 0 THEN NULL ELSE CAST(CAST(CONTRATTOSINTESI.DTRIFE AS VARCHAR(8)) AS DATETIME) END AS DATA_OPERAZIONE, --CONTRATTOSINTESI.DATADIRIFERIMENTO AS DATA_OPERAZIONE, NULL AS DATA_VALUTA, --CONVERT(DATETIME, CONTRATTOSINTESI.DATAVALNAVAL, 105) AS DATA_VALUTA, -- 105 PER FORMAT DD/MM/YYYY NULL AS DATA_REGOLAMENTO, CONTRATTOSINTESI.QUOTE AS QUANTITA, --CONTRATTOSINTESI.QUOTE AS QUANTITA, NULL AS PREZZO, --CONTRATTOSINTESI.PREZZO AS PREZZO, CONTRATTOSINTESI.CTV AS CTV, CONTRATTOSINTESI.VALORE AS CTV_NOMINALE, NULL AS VERSATO_NETTO, CONTRATTOSINTESI.PARTVIA AS PARTVIA_DISINV, CASE WHEN ISDATE(CONTRATTOSINTESI.PARTVIAAL) = 0 THEN NULL ELSE CAST(CAST(CONTRATTOSINTESI.PARTVIAAL AS VARCHAR(8)) AS DATETIME) END AS DATA_PARTVIA_DISINV, --PARTITEVIAGGIANTI.IMPVER AS PARTVIA_INV, NULL AS PARTVIA_INV, --CONTRATTOSINTESI.RENDINIZ AS REND_SOTTOSCRIZIONE, CASE WHEN (CONTRATTOSINTESI.TIPPROD = 'GE' OR CONTRATTOSINTESI.TIPPROD = 'GES') AND CONTRATTOSINTESI.DTSOTTOS < 20070101 --cast('2007-01-01' AS DATETIME) THEN NULL WHEN CONTRATTOSINTESI.TIPPROD IN ( 'ASVI','ASU1') THEN NULL --Modifica Luca WHEN CONTRATTOSINTESI.TIPPROD = 'ASUL' AND CONTRATTOSINTESI.CODINT NOT IN ('18','19','35','PR','PX') THEN NULL -- ELSE CONTRATTOSINTESI.RENDINIZ END AS REND_SOTTOSCRIZIONE, NULL AS REND_TRIMESTRE, --CONTRATTOSINTESI.RENDIMENTODAINIZIOTRIMESTRE AS REND_TRIMESTRE, CASE WHEN (CONTRATTOSINTESI.TIPPROD = 'GE' OR CONTRATTOSINTESI.TIPPROD = 'GES') AND CONTRATTOSINTESI.DTSOTTOS < 20070101 --cast('2007-01-01' AS DATETIME) THEN NULL WHEN CONTRATTOSINTESI.TIPPROD IN ( 'ASVI','ASU1') THEN NULL --Modifica Luca WHEN CONTRATTOSINTESI.TIPPROD = 'ASUL' AND CONTRATTOSINTESI.CODINT NOT IN ('18','19','35','PR','PX') THEN NULL -- ELSE CONTRATTOSINTESI.RENDANNO END AS REND_ANNO, 0 AS REND_NON_RAPPR, PRCONSUL.C_PROJECTIDM_1AF31 AS ORDINAMENTO_PROGETTO, C_BO_453FB.C_VALUE_7BD3C AS ORIZZ_TEMP_NUM, C_BO_453FB.C_DESCRIZION_93ABE AS ORIZZ_TEMP, CONSUL.TYPE$_TIPOCO_1EA7C AS STATO_CONSULENZA, ISNULL(CONVERT(DATETIME, CONSUL.C_DATAINIZIO_35C15),NULL) AS DATA_STATO_CONS, -- STRINGA IN FORMATO ISO CONSUL.C_DATAMIGRAZ_BF705 AS DATA_MIGR_CONS, PRCONSUL.C_LASTMODIFI_3BF4A AS DATA_PIANIF, 0 AS EXTRANAC, KAT.STRTYPE, KAT.COMPLEX, MIT.DESCR AS EMITTENTE, CONTRATTOSINTESI.ISIN, @ID_ELAB AS ID_ELAB, @TIPO_ELAB AS TIPO_ELAB INTO #PATRIMONIO FROM [C6StagingPeriodico].[SPB_CONTR_SINTESI] AS CONTRATTOSINTESI INNER JOIN C6STAGINGPERIODICO.ALL_CF_STATO AS ALL_CF_STATO ON ALL_CF_STATO.RETE = CONTRATTOSINTESI.RETE AND ALL_CF_STATO.CF_CLIENTE = CONTRATTOSINTESI.CODFIS AND ALL_CF_STATO.FLAG_UTILIZZO_STATO = 1 --Attuale INNER JOIN C6STAGINGPERIODICO.POSITION AS POSITION ON POSITION.POSITIONID = CONTRATTOSINTESI.POSITIONID INNER JOIN C6STAGINGPERIODICO.CONSUL AS CONSUL ON CONSUL.OID$ = POSITION.F_PCONSULENZ_56F23 AND CONSUL.TYPE$_TIPOCO_1EA7C = ALL_CF_STATO.STATO_CONSULENZA --'AttivaAggiornata' INNER JOIN C6STAGINGPERIODICO.PRCONSUL AS PRCONSUL ON PRCONSUL.OID$ = POSITION.F_PPROJECT_P_B5629 INNER JOIN C6STAGINGPERIODICO.CONSAREA AS CONSAREA ON CONSAREA.OID$ = PRCONSUL.F_PCONSULENZ_B69E4 INNER JOIN C6STAGINGPERIODICO.CATITEMREF KAT ON KAT.oid$ = POSITION.f_oid$_posit_00526 left join C6STAGINGPERIODICO.EMIT MIT ON KAT.CODEMI= MIT.CODEMI LEFT JOIN C6STAGINGPERIODICO.C_BO_453FB ON C_BO_453FB.PK_PRC = PRCONSUL.OID$ WHERE CONTRATTOSINTESI.POSITIONID IS NOT NULL and CONTRATTOSINTESI.tipprod <> 'CC' --TRINGALI --da eliminare Trimestrale Ottobre 12 --and CONTRATTOSINTESI.CODFIS not in ('CLNNNL71B67L259H', 'DNGFNC69C09E472H') --da eliminare Trimestrale Gen 2013 -- and CONTRATTOSINTESI.RETE + '-' + CONTRATTOSINTESI.CODFIS not in --('CLNNNL71B67L259H', 'DNGFNC69C09E472H') --( --'F-DLMSFN62L10F464C', --'S-FF@7888', --'F-TRLGNI38T10D325V', --'F-SRRGNE58T04H981R', --'F-MGLNTN55C23L259M', --'F-TRFRLM68H67F132X', --'F-CNTLNE72B50H501I', --'S-FRLFRC77A42H501Z' --) UNION ALL -- MODIFICA FATTA PER AVERE I CONTI CORRENTI 26 NOVEMBRE (MAURIZIO) --aggiunta consulenza per recuperare il cod progetto SELECT CONTRATTOSINTESI.RETE AS RETE, CONTRATTOSINTESI.CODFIS AS COD_FISCALE, CONTRATTOSINTESI.POSITIONID AS POSITIONID, SUBSTRING(CONTRATTOSINTESI.POSITIONID,1,57) AS COD_PRODOTTO, CONTRATTOSINTESI.CODCONF AS ID_CONTRATTO, CASE WHEN ISDATE(CONTRATTOSINTESI.DTSOTTOS) = 0 THEN NULL ELSE CAST(CAST(CONTRATTOSINTESI.DTSOTTOS AS VARCHAR(8)) AS DATETIME) END AS DATA_SOTTOSCRIZIONE, NULL AS COD_STATO, --CONTRATTOSINTESI.CODICESTATO AS COD_STATO, CONTRATTOSINTESI.NUMPOL AS NUM_POLIZZA, CONTRATTOSINTESI.MAF AS COD_MAF, CONTRATTOSINTESI.CODINT AS COD_INTERNO, CONTRATTOSINTESI.SUBPROD AS COD_SOTTOPRODOTTO, CONTRATTOSINTESI.TIPPROD AS TIPO_PRODOTTO, NULL AS NOME_PROGETTO, '' AS TIPO_PROGETTO, CASE WHEN CONTRATTOSINTESI.CTV>0 THEN 'Liq' ELSE 'Cc' END AS ID_AREA, CASE WHEN ISDATE(CONTRATTOSINTESI.DTRIFE) = 0 THEN NULL ELSE CAST(CAST(CONTRATTOSINTESI.DTRIFE AS VARCHAR(8)) AS DATETIME) END AS DATA_OPERAZIONE, --CONTRATTOSINTESI.DATADIRIFERIMENTO AS DATA_OPERAZIONE, NULL AS DATA_VALUTA, --CONVERT(DATETIME, CONTRATTOSINTESI.DATAVALNAVAL, 105) AS DATA_VALUTA, -- 105 PER FORMAT DD/MM/YYYY NULL AS DATA_REGOLAMENTO, CONTRATTOSINTESI.QUOTE AS QUANTITA, --CONTRATTOSINTESI.QUOTE AS QUANTITA, NULL AS PREZZO, --CONTRATTOSINTESI.PREZZO AS PREZZO, CONTRATTOSINTESI.CTV AS CTV, CONTRATTOSINTESI.VALORE AS CTV_NOMINALE, NULL AS VERSATO_NETTO, --CONTRATTOSINTESI.CVN AS VERSATO_NETTO, CONTRATTOSINTESI.PARTVIA AS PARTVIA_DISINV, CASE WHEN ISDATE(CONTRATTOSINTESI.PARTVIAAL) = 0 THEN NULL ELSE CAST(CAST(CONTRATTOSINTESI.PARTVIAAL AS VARCHAR(8)) AS DATETIME) END AS DATA_PARTVIA_DISINV, NULL AS PARTVIA_INV, --PARTITEVIAGGIANTI.IMPORTOVERSATO AS PARTVIA_INV, CONTRATTOSINTESI.RENDINIZ AS REND_SOTTOSCRIZIONE, NULL AS REND_TRIMESTRE, --CONTRATTOSINTESI.RENDIMENTODAINIZIOTRIMESTRE AS REND_TRIMESTRE, CONTRATTOSINTESI.RENDANNO AS REND_ANNO, 0 AS REND_NON_RAPPR, PRCONSUL.C_PROJECTIDM_1AF31 AS ORDINAMENTO_PROGETTO, null AS ORIZZ_TEMP_NUM, NULL AS ORIZZ_TEMP, NULL AS STATO_CONSULENZA, NULL AS DATA_STATO_CONS, -- STRINGA IN FORMATO ISO NULL AS DATA_MIGR_CONS, NULL AS DATA_PIANIF, 0 AS EXTRANAC, KAT.STRTYPE, KAT.COMPLEX, MIT.DESCR AS EMITTENTE, CONTRATTOSINTESI.ISIN, @ID_ELAB AS ID_ELAB, @TIPO_ELAB AS TIPO_ELAB FROM [C6StagingPeriodico].[SPB_CONTR_SINTESI] AS CONTRATTOSINTESI INNER JOIN C6STAGINGPERIODICO.CATITEMREF KAT ON SUBSTRING(CONTRATTOSINTESI.POSITIONID,1,57)=KAT.CATALOGUEID LEFT OUTER JOIN C6STAGINGPERIODICO.EMIT MIT ON MIT.CODEMI=KAT.CODEMI INNER JOIN C6STAGINGPERIODICO.ALL_CF_STATO AS ALL_CF_STATO ON ALL_CF_STATO.RETE = CONTRATTOSINTESI.RETE AND ALL_CF_STATO.CF_CLIENTE = CONTRATTOSINTESI.CODFIS AND ALL_CF_STATO.FLAG_UTILIZZO_STATO = 1 --Attuale INNER JOIN C6STAGINGPERIODICO.POSITION AS POSITION ON POSITION.POSITIONID = CONTRATTOSINTESI.POSITIONID INNER JOIN C6STAGINGPERIODICO.CONSUL AS CONSUL ON CONSUL.OID$ = POSITION.F_PCONSULENZ_56F23 AND CONSUL.TYPE$_TIPOCO_1EA7C = ALL_CF_STATO.STATO_CONSULENZA --'AttivaAggiornata' INNER JOIN C6STAGINGPERIODICO.PRCONSUL AS PRCONSUL ON PRCONSUL.OID$ = POSITION.F_PPROJECT_P_B5629 WHERE TIPPROD = 'CC' --and CONTRATTOSINTESI.CODFIS not in ('CLNNNL71B67L259H', 'DNGFNC69C09E472H') -- Log esecuzione UPDATE LOG_ESECUZIONE SET Fine = GETDATE(), Tipo = 'INSERT', Righe = @@ROWCOUNT WHERE Nome = 'DM_PATRIMONIO_BF' AND Inizio = ( SELECT MAX(Inizio) FROM LOG_ESECUZIONE WHERE Nome = 'DM_PATRIMONIO_BF' ) INSERT INTO LOG_ESECUZIONE (Nome, Inizio, Nota) VALUES ( 'DM_PATRIMONIO_BF2', GETDATE(), 'Elaborazione trimestrale' ) INSERT INTO C6MartPeriodico.[PATRIMONIO_BF] ([RETE] ,[COD_FISCALE] ,[POSITION_ID] ,[COD_PRODOTTO] ,[ID_CONTRATTO] ,[DATA_SOTTOSCRIZIONE] ,[COD_STATO] ,[NUM_POLIZZA] ,[COD_MAF] ,[COD_INTERNO] ,[COD_SOTTOPRODOTTO] ,[TIPO_PRODOTTO] ,[NOME_PROGETTO] ,[TIPO_PROGETTO] ,[ID_AREA] ,[DATA_OPERAZIONE] ,[DATA_VALUTA] ,[DATA_REGOLAMENTO] ,[QUANTITA] ,[PREZZO] ,[CTV] ,[CTV_NOMINALE] ,[VERSATO_NETTO] ,[PARTVIA_DISINV] ,[DATA_PARTVIA_DISINV] ,[PARTVIA_INV] ,[REND_SOTTOSCRIZIONE] ,[REND_TRIMESTRE] ,[REND_ANNO] ,[REND_NON_RAPPR] ,[ORDINAMENTO_PROGETTO] ,[ORIZZ_TEMP_NUM] ,[ORIZZ_TEMP] ,[STATO_CONSULENZA] ,[DATA_STATO_CONS] ,[DATA_MIGR_CONS] , [DATA_PIANIF] ,[EXTRANAC] ,[STRTYPE] ,[COMPLEX] ,[EMITTENTE] ,[ISIN] ,[ID_ELAB] ,[TIPO_ELAB]) SELECT RETE, COD_FISCALE, POSITIONID, COD_PRODOTTO, ID_CONTRATTO, DATA_SOTTOSCRIZIONE, COD_STATO, NUM_POLIZZA, COD_MAF, COD_INTERNO, COD_SOTTOPRODOTTO, TIPO_PRODOTTO, NOME_PROGETTO, TIPO_PROGETTO, ID_AREA, DATA_OPERAZIONE, DATA_VALUTA, DATA_REGOLAMENTO, QUANTITA, PREZZO, CTV, CTV_NOMINALE, VERSATO_NETTO, PARTVIA_DISINV, DATA_PARTVIA_DISINV, PARTVIA_INV, REND_SOTTOSCRIZIONE, REND_TRIMESTRE, REND_ANNO, REND_NON_RAPPR, ORDINAMENTO_PROGETTO, ORIZZ_TEMP_NUM, ORIZZ_TEMP, STATO_CONSULENZA, DATA_STATO_CONS, DATA_MIGR_CONS, DATA_PIANIF, EXTRANAC, STRTYPE, COMPLEX, EMITTENTE, ISIN, @ID_ELAB, @TIPO_ELAB FROM #PATRIMONIO UNION ALL -- MODIFICA PER AVERE TUTTI I PRODOTTI NON ALLOCATI SELECT CONTRATTOSINTESI.RETE AS RETE, CONTRATTOSINTESI.CODFIS AS COD_FISCALE, CONTRATTOSINTESI.POSITIONID AS POSITIONID, SUBSTRING(CONTRATTOSINTESI.POSITIONID,1,57) AS COD_PRODOTTO, CONTRATTOSINTESI.CODCONF AS ID_CONTRATTO, CASE WHEN ISDATE(CONTRATTOSINTESI.DTSOTTOS) = 0 THEN NULL ELSE CAST(CAST(CONTRATTOSINTESI.DTSOTTOS AS VARCHAR(8)) AS DATETIME) END AS DATA_SOTTOSCRIZIONE, NULL AS COD_STATO, --CONTRATTOSINTESI.CODICESTATO AS COD_STATO, CONTRATTOSINTESI.NUMPOL AS NUM_POLIZZA, CONTRATTOSINTESI.MAF AS COD_MAF, CONTRATTOSINTESI.CODINT AS COD_INTERNO, CONTRATTOSINTESI.SUBPROD AS COD_SOTTOPRODOTTO, CONTRATTOSINTESI.TIPPROD AS TIPO_PRODOTTO, LTRIM(RTRIM(NEWPOSITION.NOME_PROGETTO)) AS NOME_PROGETTO, '' AS TIPO_PROGETTO, --V Modifica fatta per riallocare correttamente un cc che scende dallo scarico della wseics e non è presente in consulenza e in proposta, --altrimenti verrebbe allocato a 'Na' CASE WHEN(CONTRATTOSINTESI.TIPPROD = 'CC' AND CONTRATTOSINTESI.CTV < 0) THEN 'CC' -------------------------------------------------------------------------------------------------- --modificato Emanuele --WHEN(CONTRATTOSINTESI.TIPPROD = 'CC' AND CONTRATTOSINTESI.CTV >= 0) THEN 'LIQ' WHEN(CONTRATTOSINTESI.TIPPROD = 'CC' AND CONTRATTOSINTESI.CTV >= 0) THEN 'Liq' -------------------------------------------------------------------------------------------------- ELSE ISNULL(NEWPOSITION.NEED_BREVE,'Na') END AS ID_AREA, CASE WHEN ISDATE(CONTRATTOSINTESI.DTRIFE) = 0 THEN NULL ELSE CAST(CAST(CONTRATTOSINTESI.DTRIFE AS VARCHAR(8)) AS DATETIME) END AS DATA_OPERAZIONE, --CONTRATTOSINTESI.DATADIRIFERIMENTO AS DATA_OPERAZIONE, NULL AS DATA_VALUTA, --CONVERT(DATETIME, CONTRATTOSINTESI.DATAVALNAVAL, 105) AS DATA_VALUTA, -- 105 PER FORMAT DD/MM/YYYY NULL AS DATA_REGOLAMENTO, CONTRATTOSINTESI.QUOTE AS QUANTITA, --CONTRATTOSINTESI.QUOTE AS QUANTITA, NULL AS PREZZO, --CONTRATTOSINTESI.PREZZO AS PREZZO, CONTRATTOSINTESI.CTV AS CTV, CONTRATTOSINTESI.VALORE AS CTV_NOMINALE, NULL AS VERSATO_NETTO, CONTRATTOSINTESI.PARTVIA AS PARTVIA_DISINV, CASE WHEN ISDATE(CONTRATTOSINTESI.PARTVIAAL) = 0 THEN NULL ELSE CAST(CAST(CONTRATTOSINTESI.PARTVIAAL AS VARCHAR(8)) AS DATETIME) END AS DATA_PARTVIA_DISINV, --PARTITEVIAGGIANTI.IMPVER AS PARTVIA_INV, NULL AS PARTVIA_INV, CONTRATTOSINTESI.RENDINIZ AS REND_SOTTOSCRIZIONE, NULL AS REND_TRIMESTRE, --CONTRATTOSINTESI.RENDIMENTODAINIZIOTRIMESTRE AS REND_TRIMESTRE, CONTRATTOSINTESI.RENDANNO AS REND_ANNO, 0 AS REND_NON_RAPPR, NULL AS ORDINAMENTO_PROGETTO, ORIZZ_TEMP_NUM, ORIZZ_TEMP, STATO_CONSULENZA, DATA_STATO_CONS, DATA_MIGR_CONS, DATA_PIANIF, 0 AS EXTRANAC, KAT.STRTYPE, KAT.COMPLEX, MIT.DESCR AS EMITTENTE, CONTRATTOSINTESI.ISIN, @ID_ELAB, @TIPO_ELAB FROM [C6StagingPeriodico].[SPB_CONTR_SINTESI] AS CONTRATTOSINTESI LEFT JOIN #PATRIMONIO AS PATR ON CONTRATTOSINTESI.RETE = PATR.RETE AND CONTRATTOSINTESI.CODFIS = PATR.COD_FISCALE AND CONTRATTOSINTESI.POSITIONID = PATR.POSITIONID LEFT OUTER JOIN C6STAGINGPERIODICO.CATITEMREF KAT ON SUBSTRING(CONTRATTOSINTESI.POSITIONID,1,57)=KAT.CATALOGUEID LEFT OUTER JOIN C6STAGINGPERIODICO.EMIT MIT ON MIT.CODEMI=KAT.CODEMI LEFT JOIN C6STAGINGPERIODICO.vNewPositionProposta NEWPOSITION ON CONTRATTOSINTESI.RETE = NEWPOSITION.RETE AND CONTRATTOSINTESI.CODFIS = NEWPOSITION.CODICEFISCALE AND CONTRATTOSINTESI.POSITIONID = NEWPOSITION.positionIDProposta WHERE CONTRATTOSINTESI.POSITIONID IS NOT NULL AND PATR.POSITIONID IS NULL --da eliminare Trimestrale Gen 2013 -- and CONTRATTOSINTESI.RETE + '-' + CONTRATTOSINTESI.CODFIS not in --('CLNNNL71B67L259H', 'DNGFNC69C09E472H') --( --'F-DLMSFN62L10F464C', --'S-FF@7888', --'F-TRLGNI38T10D325V', --'F-SRRGNE58T04H981R', --'F-MGLNTN55C23L259M', --'F-TRFRLM68H67F132X', --'F-CNTLNE72B50H501I', --'S-FRLFRC77A42H501Z' --) -- Log esecuzione UPDATE LOG_ESECUZIONE SET Fine = GETDATE(), Tipo = 'INSERT', Righe = @@ROWCOUNT WHERE Nome = 'DM_PATRIMONIO_BF2' AND Inizio = ( SELECT MAX(Inizio) FROM LOG_ESECUZIONE WHERE Nome = 'DM_PATRIMONIO_BF2' ) DROP TABLE #PATRIMONIO INSERT INTO LOG_ESECUZIONE (Nome, Inizio, Nota) VALUES ( 'DM_PATRIMONIO_BF3', GETDATE(), 'Elaborazione trimestrale' ) -- AGGIORNAMENTO PRODOTTI EXTRA NAC -- -- SELECT -- MISS.POSITIONID, -- MISS.CODFIS AS COD_FISCALE, -- MISS.RETE, -- C_NEEDAREA_V_46360 AS ID_AREA, -- C_PROJECTNAM_11D1A AS NOME_PROGETTO, -- C_PROJECTIDM_1AF31 AS ORDINAMENTO_PROGETTO -- INTO #MISS_PAST -- FROM -- ( -- SELECT A.POSITIONID, CODFIS, RETE -- FROM -- C6STAGINGPERIODICO.SPB_CONTR_SINTESI A -- LEFT OUTER JOIN -- ( -- SELECT D.POSITIONID, A.ADBKID, A.INSTID -- FROM -- C6STAGINGPERIODICO.CONSUL A, -- C6STAGINGPERIODICO.PRCONSUL B, -- C6STAGINGPERIODICO.CONSAREA C, -- C6STAGINGPERIODICO.POSITION D, -- C6STAGINGPERIODICO.ALL_CF_STATO F -- WHERE -- 1=1 -- AND A.OID$ = C.F_PCONSULENZ_7FBE3 -- AND B.OID$ = D.F_PPROJECT_P_B5629 -- AND C.OID$ = B.F_PCONSULENZ_B69E4 -- AND F.RETE = A.INSTID -- AND F.CF_CLIENTE = A.ADBKID -- AND F.FLAG_UTILIZZO_STATO = 1 -- AND A.TYPE$_TIPOCO_1EA7C = F.STATO_CONSULENZA -- and C.C_NEEDAREA_V_46360 <> 'Cc' -- ) B -- ON -- B.POSITIONID=A.POSITIONID -- AND B.ADBKID=A.CODFIS -- AND B.INSTID=A.RETE -- WHERE -- B.POSITIONID IS NULL -- ) MISS, -- ( -- SELECT D.POSITIONID, -- A.ADBKID, A.INSTID, -- C.C_NEEDAREA_V_46360, -- TYPE$_PROJEC_14674, -- C_PROJECTNAM_11D1A, -- C_PROJECTIDM_1AF31 -- FROM -- C6STAGINGPERIODICO.CONSUL A, -- C6STAGINGPERIODICO.PRCONSUL B, -- C6STAGINGPERIODICO.CONSAREA C, -- C6STAGINGPERIODICO.POSITION D -- WHERE -- 1=1 -- AND A.OID$ = C.F_PCONSULENZ_7FBE3 -- AND B.OID$ = D.F_PPROJECT_P_B5629 -- AND C.OID$ = B.F_PCONSULENZ_B69E4 -- AND A.TYPE$_TIPOCO_1EA7C = 'Attiva' -- and C.C_NEEDAREA_V_46360 <> 'Cc' -- ) PAST -- WHERE -- MISS.POSITIONID=PAST.POSITIONID -- AND MISS.CODFIS=PAST.ADBKID --- MISS SELECT A.POSITIONID, CODFIS, RETE into #MISS FROM C6STAGINGPERIODICO.SPB_CONTR_SINTESI A LEFT OUTER JOIN ( SELECT D.POSITIONID, A.ADBKID, A.INSTID FROM C6STAGINGPERIODICO.CONSUL A, C6STAGINGPERIODICO.PRCONSUL B, C6STAGINGPERIODICO.CONSAREA C, C6STAGINGPERIODICO.POSITION D, C6STAGINGPERIODICO.ALL_CF_STATO F WHERE 1=1 AND A.OID$ = C.F_PCONSULENZ_7FBE3 AND B.OID$ = D.F_PPROJECT_P_B5629 AND C.OID$ = B.F_PCONSULENZ_B69E4 AND F.RETE = A.INSTID AND F.CF_CLIENTE = A.ADBKID AND F.FLAG_UTILIZZO_STATO = 1 AND A.TYPE$_TIPOCO_1EA7C = F.STATO_CONSULENZA --and C.C_NEEDAREA_V_46360 <> 'Cc' and D.type$_catalo_35E2a <> 'ContiCorrenti' ) B ON B.POSITIONID=A.POSITIONID AND B.ADBKID=A.CODFIS AND B.INSTID=A.RETE WHERE B.POSITIONID IS NULL -- PAST SELECT D.POSITIONID, A.ADBKID, A.INSTID, C.C_NEEDAREA_V_46360, TYPE$_PROJEC_14674, C_PROJECTNAM_11D1A, C_PROJECTIDM_1AF31 into #PAST FROM C6STAGINGPERIODICO.CONSUL A, C6STAGINGPERIODICO.PRCONSUL B, C6STAGINGPERIODICO.CONSAREA C, C6STAGINGPERIODICO.POSITION D WHERE 1=1 AND A.OID$ = C.F_PCONSULENZ_7FBE3 AND B.OID$ = D.F_PPROJECT_P_B5629 AND C.OID$ = B.F_PCONSULENZ_B69E4 AND A.TYPE$_TIPOCO_1EA7C = 'Attiva' --and C.C_NEEDAREA_V_46360 <> 'Cc' and D.type$_catalo_35E2a <> 'ContiCorrenti' SELECT MISS.POSITIONID, MISS.CODFIS AS COD_FISCALE, MISS.RETE, C_NEEDAREA_V_46360 AS ID_AREA, C_PROJECTNAM_11D1A AS NOME_PROGETTO, C_PROJECTIDM_1AF31 AS ORDINAMENTO_PROGETTO INTO #miss_PAST FROM #MISS miss, #PAST past WHERE MISS.POSITIONID=PAST.POSITIONID AND MISS.CODFIS=PAST.ADBKID UPDATE PATR_BF SET PATR_BF.ID_AREA = MISS_PAST.ID_AREA, PATR_BF.NOME_PROGETTO = MISS_PAST.NOME_PROGETTO, PATR_BF.ORDINAMENTO_PROGETTO = MISS_PAST.ORDINAMENTO_PROGETTO, PATR_BF.EXTRANAC = 1 FROM C6MartPeriodico.PATRIMONIO_BF AS PATR_BF INNER JOIN #MISS_PAST AS MISS_PAST ON PATR_BF.RETE = MISS_PAST.RETE AND PATR_BF.COD_FISCALE = MISS_PAST.COD_FISCALE AND PATR_BF.POSITION_ID = MISS_PAST.POSITIONID -- Log esecuzione UPDATE LOG_ESECUZIONE SET Fine = GETDATE(), Tipo = 'UPDATE', Righe = @@ROWCOUNT WHERE Nome = 'DM_PATRIMONIO_BF3' AND Inizio = ( SELECT MAX(Inizio) FROM LOG_ESECUZIONE WHERE Nome = 'DM_PATRIMONIO_BF3' ) DROP TABLE #MISS_PAST INSERT INTO LOG_ESECUZIONE (Nome, Inizio, Nota) VALUES ( 'DM_PATRIMONIO_BF4', GETDATE(), 'Elaborazione trimestrale' ) -- IMPOSTA IL FLAG DEI PRODOTTI CON RENDIMENTO NON RAPPRESENTABILE UPDATE PATR_BF SET PATR_BF.REND_NON_RAPPR = 1 FROM ( SELECT TSCA.RETE, TSCA.CODFIS, C6StagingPeriodico.RP_Info_DaProdottoCSaCatalogo( TSCA.TIPPROD, PRC.COD_INTERNO, PRC.COD_MAF, '', TSCA.SUBPROD ) + dbo.Crea_positionID( TSCA.TIPPROD, PRC.COD_INTERNO, PRC.COD_MAF, '', TSCA.SUBPROD, TSCA.CODCONF, PRC.NUMPOL, TSCA.CONTO, TSCA.RUBR, TSCA.CUSTGAR, TSCA.TERMID, TSCA.ANNO, TSCA.PROG ) AS POSITION_ID FROM C6StagingPeriodico.TSCABP AS TSCA inner join C6StagingPeriodico.tcptab as TCP ON TCP.CODFIS=TSCA.CODFIS AND TCP.RETE=TSCA.RETE AND TCP.CODCONF=TSCA.CODCONF AND TCP.CODPROG=TSCA.CODPROG AND TCP.CODPROD=TSCA.CODPROD AND TCP.CONTO=TSCA.CONTO AND TCP.CUSTGAR=TSCA.CUSTGAR AND TCP.CODABI=TSCA.CODABI AND ISNULL(TCP.PROG,'XXX')=ISNULL(TSCA.PROG,'XXX') AND ISNULL(TCP.TERMID,'XXX')=ISNULL(TSCA.TERMID,'XXX') AND ISNULL(TCP.ANNO,'XXX')=ISNULL(TSCA.ANNO,'XXX') INNER JOIN C6StagingPeriodico.ALL_POS_CONS_CAT AS PRC ON TSCA.CODPROG = PRC.ID_MONITORAGGIO AND TSCA.CODCONF = PRC.CONTRATTO AND REPLACE(TSCA.SUBPROD, ' ', '$') = PRC.COD_SOTTOPRODOTTO AND TCP.CODINT = PRC.COD_INTERNO WHERE TSCA.DTRIF <> 0 ) REND_NON_RAPPR INNER JOIN C6MartPeriodico.PATRIMONIO_BF AS PATR_BF ON PATR_BF.RETE = REND_NON_RAPPR.RETE AND PATR_BF.COD_FISCALE = --V REND_NON_RAPPR.CODFIS --FF@4546 4546 CASE WHEN(SUBSTRING(PATR_BF.COD_FISCALE,1,3) = 'FF@') THEN 'FF@'+REND_NON_RAPPR.CODFIS ELSE REND_NON_RAPPR.CODFIS END AND PATR_BF.POSITION_ID = REND_NON_RAPPR.POSITION_ID -- Log esecuzione UPDATE LOG_ESECUZIONE SET Fine = GETDATE(), Tipo = 'UPDATE', Righe = @@ROWCOUNT WHERE Nome = 'DM_PATRIMONIO_BF4' AND Inizio = ( SELECT MAX(Inizio) FROM LOG_ESECUZIONE WHERE Nome = 'DM_PATRIMONIO_BF4' ) -- Log esecuzione INSERT INTO LOG_ESECUZIONE (Nome, Inizio, Nota) VALUES ( 'DM_PATRIMONIO_BF5', GETDATE(), 'Elaborazione trimestrale' ) SELECT ALL_CF_PB.RETE_PB AS RETE, ALL_CF_PB.CODICE_FISCALE AS COD_FISCALE, CONSAREA.C_NEEDAREA_V_46360 AS ID_AREA, PRCONSUL.C_PROJECTNAM_11D1A AS NOME_PROGETTO, PRCONSUL.TYPE$_PROJEC_14674 AS TIPO_PROGETTO, PRCONSUL.C_PERCENTUAL_69019 AS PERC_AREA, PRCONSUL.C_PROJECTCTV_39520 AS CTV_PROGETTO, CONSAREA.C_CTVNEEDARE_EA4FB AS CTV_AREA, C_BO_453FB.C_VALUE_7BD3C AS ORIZZ_TEMP_NUM, C_BO_453FB.C_DESCRIZION_93ABE AS ORIZZ_TEMP, NULL AS CTV_TOTALE, CONSUL.TYPE$_TIPOCO_1EA7C AS STATO_CONSULENZA, ISNULL(CONVERT(DATETIME, CONSUL.C_DATAINIZIO_35C15),NULL) AS DATA_STATO_CONS, -- STRINGA IN FORMATO ISO CONSUL.C_DATAMIGRAZ_BF705 AS DATA_MIGR_CONS, PRCONSUL.C_LASTMODIFI_3BF4A AS DATA_PIANIF, NULL AS ID_CONTRATTO, PRCONSUL.C_PROJECTIDM_1AF31 AS ORDINAMENTO_PROGETTO into #AGG_PROG FROM C6STAGINGPERIODICO.ALL_CF_PB INNER JOIN C6STAGINGPERIODICO.CONSUL ON CONSUL.INSTID = ALL_CF_PB.RETE_PB AND CONSUL.ADBKID = ALL_CF_PB.CODICEFISCALE AND CONSUL.TYPE$_TIPOCO_1EA7C = 'Bozza' INNER JOIN C6STAGINGPERIODICO.CONSAREA ON CONSAREA.F_PCONSULENZ_7FBE3 = CONSUL.OID$ INNER JOIN C6STAGINGPERIODICO.PRCONSUL ON PRCONSUL.F_PCONSULENZ_B69E4 = CONSAREA.OID$ LEFT JOIN C6STAGINGPERIODICO.C_BO_453FB ON C_BO_453FB.PK_PRC = PRCONSUL.OID$ where CONSAREA.C_NEEDAREA_V_46360='Inv' UPDATE C6MARTPERIODICO.PATRIMONIO_BF SET NOME_PROGETTO = L.NOME_PROGETTO FROM #AGG_PROG L WHERE C6MARTPERIODICO.PATRIMONIO_BF.COD_FISCALE=L.COD_FISCALE AND C6MARTPERIODICO.PATRIMONIO_BF.RETE=L.RETE AND C6MARTPERIODICO.PATRIMONIO_BF.ORDINAMENTO_PROGETTO=L.ORDINAMENTO_PROGETTO AND C6MARTPERIODICO.PATRIMONIO_BF.NOME_PROGETTO <> L.NOME_PROGETTO UPDATE C6MARTPERIODICO.PATRIMONIO_BF SET REND_NON_RAPPR=1 FROM C6MARTPERIODICO.PATRIMONIO_BF WHERE TIPO_PRODOTTO='CC' AND CTV > 0 AND ID_AREA='Liq' --aggiunta Emanuele/Valerio UPDATE c6martperiodico.patrimonio_bf SET Id_area = 'Liq' WHERE TIPO_PRODOTTO='CC' AND ID_AREA = 'na' AND CTV > 0 --aggiunta Emanuele UPDATE c6martperiodico.patrimonio_bf SET id_area = 'Liq' WHERE id_area = 'LIQ' --------------------------------------- UPDATE C6MARTPERIODICO.PATRIMONIO_BF SET NOME_PROGETTO = LTRIM(RTRIM(NOME_PROGETTO)) -- Log esecuzione UPDATE LOG_ESECUZIONE SET Fine = GETDATE(), Tipo = 'UPDATE', Righe = @@ROWCOUNT WHERE Nome = 'DM_PATRIMONIO_BF5' AND Inizio = ( SELECT MAX(Inizio) FROM LOG_ESECUZIONE WHERE Nome = 'DM_PATRIMONIO_BF5' ) END