合并两个程序

时间:2017-07-31 19:45:34

标签: stored-procedures merge sap hana hana-sql-script

我已经看到了一些类似的问题,但没有多少帮助。 我已经有两个程序,我需要合并它,并将内部表TT_SERIES替换为名为DB_WEEK_SERIES的数据库表。我试图合并但有错误。以下是我的2个程序: -

第1程序:

 PROCEDURE 
 "AFS_BASE"."AFS_BASE.KPI.DASHBOARD::PR_REV_CTRL_BOX_ORDER_BY_STAGE" 
 (  
    IN TT_INPUT "OPS_SCHEMA"."AM.OPS.CORE.TABLETYPES::GTT_INPUT", 
   OUT TT_DASHBOARD "OPS_SCHEMA"."AM.OPS.CORE.TABLETYPES::GTT_GENERIC_DASHBOARD"
)
LANGUAGE SQLSCRIPT
SQL SECURITY INVOKER 
DEFAULT SCHEMA AFS_BASE
AS

LV_TAB          NVARCHAR(50) ;
lv_measure      nvarchar(50) ;
lv_report_date  date ;
LV_UID          NVARCHAR(255);
LV_SUB_HEADING  NVARCHAR(255);
LV_START_DATE   DATE := ADD_DAYS (LAST_DAY (ADD_MONTHS(CURRENT_DATE, -4)), 
1);
LV_END_DATE     DATE := LAST_DAY (CURRENT_DATE);
LV_WEEKEND      NVARCHAR(10) := 'FRIDAY';

/**********************************
Created by Junaid on 13th May 2017
**********************************/

BEGIN

SELECT VALUE INTO LV_UID FROM :TT_INPUT WHERE VARIABLE = 'UID';
SELECT VALUE INTO LV_TAB FROM :TT_INPUT WHERE VARIABLE = 'TAB';
SELECT IFNULL(NULLIF(VALUE,''),:LV_START_DATE) INTO LV_START_DATE FROM 
:TT_INPUT where VARIABLE = 'START_DATE';  
SELECT IFNULL(NULLIF(VALUE,''),:LV_END_DATE) INTO LV_END_DATE FROM :TT_INPUT 
where VARIABLE = 'END_DATE';

BEGIN

    DECLARE EXIT HANDLER FOR SQL_ERROR_CODE 1299

    LV_SUB_HEADING := '';
    SELECT VALUE INTO LV_SUB_HEADING FROM :TT_INPUT WHERE VARIABLE = 
    'SUB_HEADING';

    END;


    TT_HDR = SELECT DISTINCT SERIAL_NUMBER 
        FROM "AFS_BASE"."AFS_BASE.TRENDS.TABLES::OPV_KPI_MEASURES"
        WHERE MEASURE_DATE BETWEEN :LV_START_DATE AND :LV_END_DATE;

   TT_ZOOM =    SELECT 'ATTRIBUTE' AS ZOOM_TYPE,
                    Z.ATTRIBUTE AS ZOOM_ATTRIBUTE,
                    Z.ATTRIBUTE_VALUE AS ZOOM_ATTRIBUTE_VALUE
              FROM "BASE_SCHEMA"."AM.BASE.TABLES::DB_TAB_ZOOM_VALUES" Z
             WHERE Z.TAB_NAME = :LV_TAB 
               AND Z.SCENARIO_NUMBER = SESSION_CONTEXT('$vssod_scenario')
               AND Z.SESSION_ID = SESSION_CONTEXT('$vssod_sid') 
               AND Z.USER_NAME = SESSION_USER
               AND Z.ATTRIBUTE IN (SELECT ATTRIBUTE FROM 
               "BASE_SCHEMA"."AM.BASE.TABLES::DB_CONFIG_ATTRIBUE"
                                   WHERE CLIENT = SESSION_CONTEXT('CLIENT') 
             AND DISPLAY = 'Y')
             UNION ALL
            SELECT 'TAG' AS ZOOM_TYPE,
                   Z.ATTRIBUTE AS ZOOM_ATTRIBUTE,
                   Z.ATTRIBUTE_VALUE AS ZOOM_ATTRIBUTE_VALUE
              FROM "BASE_SCHEMA"."AM.BASE.TABLES::DB_TAB_ZOOM_VALUES" Z
             WHERE TAB_NAME = :LV_TAB 
               AND Z.SCENARIO_NUMBER= SESSION_CONTEXT('$vssod_scenario')
               AND Z.SESSION_ID = SESSION_CONTEXT('$vssod_sid') 
               AND Z.USER_NAME = SESSION_USER
               AND Z.ATTRIBUTE IN (SELECT TAG_NAME FROM 
             "BASE_SCHEMA"."AM.BASE.TABLES::DB_CONFIG_TAGS"
                                   WHERE CLIENT = SESSION_CONTEXT('CLIENT') 
             AND DISPLAY = 'Y'); 

             CALL "AFS_BASE"."AFS_BASE.TRENDS.CORE/PR_KPI_FILTER_WITH_ZOOM"
             (:TT_INPUT, :TT_ZOOM, :TT_HDR, TT_FSN);

            TT_SERIES = SELECT GENERATED_PERIOD_START AS REPORT_DATE,
                     week(add_days(generated_period_start , 2)) as 
            report_week, current_date as week_end --added ABHOOT
               FROM SERIES_GENERATE_DATE ( 'INTERVAL 1 DAY', :LV_START_DATE, 

           ADD_DAYS(coalesce(current_date,:LV_END_DATE), 1));

           TT_WEEK_END = select report_week, max(report_date) as week_end
                  from :TT_SERIES
                  group by report_week ;


           TT_SERIES = select S.report_date, w.report_week, w.week_end
               from :TT_WEEK_END W
               inner join :TT_SERIES S
               on w.report_week = s.report_week ;

          select SUBSTR_AFTER(:lv_uid, ':') into lv_measure from dummy ;
          select SUBSTR_BEFORE (:lv_uid, ':') into lv_report_date from dummy 
          ;

         IF :LV_UID = 'ALL' THEN
         TT_INVOICED = SELECT 0 as serial_number , week_end as REPORT_DATE, 
         SUM(MEASURE_AMOUNT) AS INV_AMT
                    FROM 
         "AFS_BASE"."AFS_BASE.TRENDS.TABLES::OPV_KPI_MEASURES" K
                    INNER JOIN :TT_SERIES TS
                    ON TS.REPORT_DATE = K.MEASURE_DATE
                    where MEASURE = 'Invoiced'
                    and k.serial_number in (select distinct serial_number 
         from :TT_FSN )
                    GROUP BY week_end;

    TT_INVOICE = SELECT REPORT_DATE, 'Invoiced' AS MEASURE, SUM(INV_AMT) AS 
    AMT
                    FROM :TT_INVOICED I
                    GROUP BY report_date ;

    TT_REMAINING = SELECT 0 as SERIAL_NUMBER, ts.week_end as REPORT_DATE, 
    MEASURE, SUM(MEASURE_AMOUNT) AS AMT
                    FROM 
   "AFS_BASE"."AFS_BASE.TRENDS.TABLES::OPV_KPI_MEASURES" K
                    INNER JOIN :TT_week_end TS
                    ON TS.WEEK_END BETWEEN K.VALID_FROM_DATE AND 
    K.VALID_TO_DATE
                    where k.MEASURE IN ('In Pick', 'In Production', 'In 
    Transit', 'Late', 'Not Covered', 'On Hand', 'Open Direct Ship')
                    and k.serial_number in (select distinct serial_number 
    from :TT_FSN )
                    GROUP BY TS.week_end, MEASURE ;


    TT_DATA = SELECT REPORT_DATE, MEASURE, SUM(AMT) AS TOT_AMT, 1 AS SORT 
    FROM :TT_INVOICE
                GROUP BY REPORT_DATE, MEASURE
                UNION ALL
                SELECT REPORT_DATE, MEASURE, SUM(AMT) AS TOT_AMT, 2 AS SORT 
    FROM :TT_REMAINING
                GROUP BY REPORT_DATE, MEASURE;

  ELSEIF  :lv_measure =  'Invoiced' THEN        
    TT_DRILLDOWN = SELECT K.serial_number, week_end as REPORT_DATE, k.measure, SUM(MEASURE_AMOUNT) AS AMT
                    FROM "AFS_BASE"."AFS_BASE.TRENDS.TABLES::OPV_KPI_MEASURES" K
                    INNER JOIN :TT_SERIES TS
                    ON TS.REPORT_DATE = K.MEASURE_DATE
                    and ts.week_end = :lv_report_date
                    where MEASURE = 'Invoiced'
                    and k.serial_number in (select distinct serial_number from :TT_FSN )
                    GROUP BY week_end, k.measure, K.serial_number ;
  ELSEIF  :lv_measure <> 'Invoiced' THEN  
    TT_DRILLDOWN = SELECT k.SERIAL_NUMBER, :lv_report_date as  REPORT_DATE, MEASURE, SUM(MEASURE_AMOUNT) AS AMT
                    FROM "AFS_BASE"."AFS_BASE.TRENDS.TABLES::OPV_KPI_MEASURES" K
                    where k.MEASURE = :lv_measure
                    and :lv_report_date BETWEEN K.VALID_FROM_DATE AND K.VALID_TO_DATE
                    and k.serial_number in (select distinct serial_number from :TT_FSN )
                    GROUP BY MEASURE, K.serial_number ;
  END IF ;


    /* TT_WEEKLY = SELECT REPORT_DATE, COALESCE(ADD_DAYS(LAG(REPORT_DATE,1) OVER (ORDER BY REPORT_DATE), 1), :LV_START_DATE) AS PREV_REPORT_DATE
                FROM ( SELECT REPORT_DATE FROM :TT_SERIES WHERE DAYNAME(REPORT_DATE) = 'FRIDAY'); */


    IF :LV_UID = 'ALL' THEN

    TT_DASHBOARD =       SELECT REPORT_DATE AS "NAME",
                          NULL AS "HEADING",
                          'GRAPH' AS "SUB_HEADING", 
                          MEASURE AS "SUB_CAT1",
                          NULL AS "SUB_CAT2",
                          SORT AS "SORT1",
                          NULL AS "SORT2", 
                          ROUND(TOT_AMT/1000000, 2) AS "VALUE",
                          NULL AS "SERIAL_NUMBER",
                          NULL AS "UNIT",
                          TO_CHAR (REPORT_DATE) || ':' || measure AS "UID",
                          NULL AS FREQUENCY,
                          'DRILL_DOWN' AS "HYPER_LINK",
                          '$POST=M$;$Y=Value in M$' AS "AI",        
                          NULL AS "TYPE",
                          NULL AS SIZE
                          FROM :TT_DATA
                          ORDER BY REPORT_DATE;

    ELSE

    TT_DASHBOARD =       SELECT NULL AS "NAME",
                          NULL AS "HEADING",
                          NULL AS "SUB_HEADING", 
                          NULL AS "SUB_CAT1",
                          NULL AS "SUB_CAT2",
                          NULL AS "SORT1",
                          NULL AS "SORT2", 
                          NULL AS "VALUE",
                          SERIAL_NUMBER AS "SERIAL_NUMBER",
                          NULL AS "UNIT",
                          NULL AS "UID",
                          NULL AS FREQUENCY,
                          NULL AS "HYPER_LINK",
                          NULL AS "AI",         
                          NULL AS "TYPE",
                          NULL AS SIZE
                          FROM :TT_DRILLDOWN ORDER BY AMT DESC
                          LIMIT 10000;

    END IF;

    END;

程序2: -

    CREATE PROCEDURE bhavya.zz_get_series()

    LANGUAGE SQLSCRIPT AS
   --SQL SECURITY INVOKER 
   --DEFAULT SCHEMA <default_schema_name>

LV_START_DATE   DATE    := '2010-01-01' ;
LV_END_DATE     DATE    := '2031-01-01' ;

BEGIN
DECLARE REPORT_WEEK_INIT integer := ABS(WEEKDAY(LV_START_DATE) - 4);

TT_SERIES = 
(SELECT 
    GENERATED_PERIOD_START AS REPORT_DATE,
    CASE WHEN WEEKDAY(GENERATED_PERIOD_START) > 4 THEN 
        ADD_DAYS(GENERATED_PERIOD_START, WEEKDAY(GENERATED_PERIOD_START) + 
        CASE WHEN WEEKDAY(GENERATED_PERIOD_START)=5 THEN 1 ELSE -1 END) 
    ELSE 
        ADD_DAYS(GENERATED_PERIOD_START, 4-WEEKDAY(GENERATED_PERIOD_START)) 
    END AS WEEK_END
FROM SERIES_GENERATE_DATE ( 'INTERVAL 1 DAY', :LV_START_DATE, COALESCE(:LV_END_DATE, CURRENT_DATE)));

INSERT INTO  "BHAVYA"."AFS_BASE.KPI.TABLES::DB_WEEK_SERIES"( REPORT_DATE, REPORT_WEEK, WEEK_END )
SELECT REPORT_DATE, WEEK(WEEK_END), WEEK_END
FROM :TT_SERIES;

END;

感谢任何帮助。谢谢。 我的下面的代码显示了我如何尝试合并但失败了: -

 PROCEDURE 
"AFS_BASE"."AFS_BASE.KPI.DASHBOARD::PR_REV_CTRL_BOX_ORDER_BY_STAGE_V1" 
(  
IN TT_INPUT "OPS_SCHEMA"."AM.OPS.CORE.TABLETYPES::GTT_INPUT", 
OUT TT_DASHBOARD 
"OPS_SCHEMA"."AM.OPS.CORE.TABLETYPES::GTT_GENERIC_DASHBOARD" 
)

LANGUAGE SQLSCRIPT
SQL SECURITY INVOKER 
DEFAULT SCHEMA AFS_BASE
AS



LV_TAB          NVARCHAR(50) ;
lv_measure      nvarchar(50) ;
lv_report_date  date ;
LV_UID          NVARCHAR(255);
LV_SUB_HEADING  NVARCHAR(255);
LV_START_DATE   DATE    := '2010-01-01' ; 
LV_END_DATE     DATE    := '2031-01-01' ;
LV_WEEKEND      NVARCHAR(10) := 'FRIDAY';

/**********************************
Created by Junaid on 13th May 2017
**********************************/

BEGIN

DECLARE REPORT_WEEK_INIT integer := ABS(WEEKDAY(LV_START_DATE) - 4);

TT_SERIES = 
(SELECT 
    GENERATED_PERIOD_START AS REPORT_DATE,
    CASE WHEN WEEKDAY(GENERATED_PERIOD_START) > 4 THEN 
        ADD_DAYS(GENERATED_PERIOD_START, WEEKDAY(GENERATED_PERIOD_START) + 
        CASE WHEN WEEKDAY(GENERATED_PERIOD_START)=5 THEN 1 ELSE -1 END) 
    ELSE 
        ADD_DAYS(GENERATED_PERIOD_START, 4-WEEKDAY(GENERATED_PERIOD_START)) 
    END AS WEEK_END
FROM SERIES_GENERATE_DATE ( 'INTERVAL 1 DAY', :LV_START_DATE, 
COALESCE(:LV_END_DATE, CURRENT_DATE))) ;


SELECT VALUE INTO LV_UID FROM :TT_INPUT WHERE VARIABLE = 'UID';
SELECT VALUE INTO LV_TAB FROM :TT_INPUT WHERE VARIABLE = 'TAB';
SELECT IFNULL(NULLIF(VALUE,''),:LV_START_DATE) INTO LV_START_DATE FROM 
:TT_INPUT where VARIABLE = 'START_DATE';  
SELECT IFNULL(NULLIF(VALUE,''),:LV_END_DATE) INTO LV_END_DATE FROM :TT_INPUT 
where VARIABLE = 'END_DATE';

BEGIN

    DECLARE EXIT HANDLER FOR SQL_ERROR_CODE 1299

    LV_SUB_HEADING := '';
    SELECT VALUE INTO LV_SUB_HEADING FROM :TT_INPUT WHERE VARIABLE = 
'SUB_HEADING';

END;




TT_HDR =
    SELECT DISTINCT SERIAL_NUMBER 
    FROM "AFS_BASE"."AFS_BASE.TRENDS.TABLES::OPV_KPI_MEASURES"
    WHERE MEASURE_DATE BETWEEN :LV_START_DATE AND :LV_END_DATE;

TT_ZOOM =   
    SELECT 
        'ATTRIBUTE' AS ZOOM_TYPE,
        Z.ATTRIBUTE AS ZOOM_ATTRIBUTE,
        Z.ATTRIBUTE_VALUE AS ZOOM_ATTRIBUTE_VALUE
    FROM "BASE_SCHEMA"."AM.BASE.TABLES::DB_TAB_ZOOM_VALUES" Z
    WHERE 
        Z.TAB_NAME = :LV_TAB 
        AND Z.SCENARIO_NUMBER = SESSION_CONTEXT('$vssod_scenario')
        AND Z.SESSION_ID = SESSION_CONTEXT('$vssod_sid') 
        AND Z.USER_NAME = SESSION_USER
        AND Z.ATTRIBUTE IN (
            SELECT ATTRIBUTE 
            FROM "BASE_SCHEMA"."AM.BASE.TABLES::DB_CONFIG_ATTRIBUE"
            WHERE CLIENT = SESSION_CONTEXT('CLIENT') AND DISPLAY = 'Y')

    UNION ALL

    SELECT 
        'TAG' AS ZOOM_TYPE,
        Z.ATTRIBUTE AS ZOOM_ATTRIBUTE,
        Z.ATTRIBUTE_VALUE AS ZOOM_ATTRIBUTE_VALUE
    FROM "BASE_SCHEMA"."AM.BASE.TABLES::DB_TAB_ZOOM_VALUES" Z
    WHERE 
        TAB_NAME = :LV_TAB 
        AND Z.SCENARIO_NUMBER= SESSION_CONTEXT('$vssod_scenario')
        AND Z.SESSION_ID = SESSION_CONTEXT('$vssod_sid') 
        AND Z.USER_NAME = SESSION_USER
        AND Z.ATTRIBUTE IN (
            SELECT TAG_NAME 
            FROM "BASE_SCHEMA"."AM.BASE.TABLES::DB_CONFIG_TAGS"
            WHERE CLIENT = SESSION_CONTEXT('CLIENT') AND DISPLAY = 'Y'); 

CALL "AFS_BASE"."AFS_BASE.TRENDS.CORE/PR_KPI_FILTER_WITH_ZOOM"(:TT_INPUT, 
:TT_ZOOM, :TT_HDR, TT_FSN);


SELECT SUBSTR_AFTER(:lv_uid, ':') into lv_measure from dummy ;
SELECT SUBSTR_BEFORE (:lv_uid, ':') into lv_report_date from dummy ;

IF :LV_UID = 'ALL' THEN
    TT_INVOICED = 
        SELECT 
            0 as serial_number, 
            week_end as REPORT_DATE, 
            SUM(MEASURE_AMOUNT) AS INV_AMT
        FROM "AFS_BASE"."AFS_BASE.TRENDS.TABLES::OPV_KPI_MEASURES" K
        INNER JOIN "AFS_BASE"."AFS_BASE::DB_WEEK_SERIES" TS
            ON TS.REPORT_DATE = K.MEASURE_DATE
        WHERE 
            MEASURE = 'Invoiced'
            and k.serial_number in (select distinct serial_number from 
   :TT_FSN )
        GROUP BY week_end;

    TT_INVOICE = 
        SELECT REPORT_DATE, 'Invoiced' AS MEASURE, SUM(INV_AMT) AS AMT
                    FROM :TT_INVOICED I
                    GROUP BY report_date ;

    TT_REMAINING = 
        SELECT 
            0 as SERIAL_NUMBER, 
            ts.week_end as REPORT_DATE, 
            MEASURE, SUM(MEASURE_AMOUNT) AS AMT
        FROM "AFS_BASE"."AFS_BASE.TRENDS.TABLES::OPV_KPI_MEASURES" K
        INNER JOIN :TT_week_end TS
            ON TS.WEEK_END BETWEEN K.VALID_FROM_DATE AND K.VALID_TO_DATE
        WHERE 
            k.MEASURE IN ('In Pick', 'In Production', 'In Transit', 'Late', 
      'Not Covered', 'On Hand', 'Open Direct Ship')
            and k.serial_number in (select distinct serial_number from 
      :TT_FSN )
        GROUP BY TS.week_end, MEASURE ;


      TT_DATA = 
        SELECT REPORT_DATE, MEASURE, SUM(AMT) AS TOT_AMT, 1 AS SORT FROM 
     :TT_INVOICE
        GROUP BY REPORT_DATE, MEASURE

        UNION ALL

        SELECT REPORT_DATE, MEASURE, SUM(AMT) AS TOT_AMT, 2 AS SORT FROM 
   :TT_REMAINING
        GROUP BY REPORT_DATE, MEASURE;

   ELSEIF  :lv_measure =  'Invoiced' THEN        
    TT_DRILLDOWN = 
        SELECT 
            K.serial_number, week_end as REPORT_DATE, 
            k.measure, SUM(MEASURE_AMOUNT) AS AMT
        FROM "AFS_BASE"."AFS_BASE.TRENDS.TABLES::OPV_KPI_MEASURES" K
        INNER JOIN "AFS_BASE"."AFS_BASE::DB_WEEK_SERIES" TS
            ON TS.REPORT_DATE = K.MEASURE_DATE and ts.week_end = 
      :lv_report_date
        where 
            MEASURE = 'Invoiced'
            and k.serial_number in (select distinct serial_number from 
      :TT_FSN )
        GROUP BY week_end, k.measure, K.serial_number ;
ELSEIF  :lv_measure <> 'Invoiced' THEN  
    TT_DRILLDOWN = 
        SELECT 
            k.SERIAL_NUMBER, :lv_report_date as  REPORT_DATE, 
            MEASURE, SUM(MEASURE_AMOUNT) AS AMT
        FROM "AFS_BASE"."AFS_BASE.TRENDS.TABLES::OPV_KPI_MEASURES" K
        where 
            k.MEASURE = :lv_measure
            and :lv_report_date BETWEEN K.VALID_FROM_DATE AND 
     K.VALID_TO_DATE
            and k.serial_number in (select distinct serial_number from 
   :TT_FSN )
        GROUP BY MEASURE, K.serial_number ;
  END IF ;

IF :LV_UID = 'ALL' THEN

    TT_DASHBOARD =       
        SELECT 
            REPORT_DATE AS "NAME",
            NULL AS "HEADING",
            'GRAPH' AS "SUB_HEADING", 
            MEASURE AS "SUB_CAT1",
            NULL AS "SUB_CAT2",
            SORT AS "SORT1",
            NULL AS "SORT2", 
            ROUND(TOT_AMT/1000000, 2) AS "VALUE",
            NULL AS "SERIAL_NUMBER",
            NULL AS "UNIT",
            TO_CHAR (REPORT_DATE) || ':' || measure AS "UID",
            NULL AS FREQUENCY,
            'DRILL_DOWN' AS "HYPER_LINK",
            '$POST=M$;$Y=Value in M$' AS "AI",          
            NULL AS "TYPE",
            NULL AS SIZE
            FROM :TT_DATA
            ORDER BY REPORT_DATE;

    ELSE

    TT_DASHBOARD =       
        SELECT 
            NULL AS "NAME",
            NULL AS "HEADING",
            NULL AS "SUB_HEADING", 
            NULL AS "SUB_CAT1",
            NULL AS "SUB_CAT2",
            NULL AS "SORT1",
            NULL AS "SORT2", 
            NULL AS "VALUE",
            SERIAL_NUMBER AS "SERIAL_NUMBER",
            NULL AS "UNIT",
            NULL AS "UID",
            NULL AS FREQUENCY,
            NULL AS "HYPER_LINK",
            NULL AS "AI",       
            NULL AS "TYPE",
            NULL AS SIZE
            FROM :TT_DRILLDOWN ORDER BY AMT DESC
            LIMIT 10000;

    END IF;

  INSERT INTO "AFS_BASE"."AFS_BASE::DB_WEEK_SERIES" ( REPORT_DATE, 
  REPORT_WEEK, WEEK_END )
SELECT REPORT_DATE, WEEK(WEEK_END), WEEK_END
FROM :TT_SERIES;


END;

错误显示我在SERIES_GENERATE_DATE附近并说出语法错误。 “;”不正确或放错地方。我认为这是错误的。但我不知道如何解决它。

0 个答案:

没有答案