修改oracle获取部门和坐席业绩的代码。
This commit is contained in:
		@@ -52,18 +52,18 @@ CREATE OR REPLACE PACKAGE BODY TELSALE_ARCHIEVEMENT_PKG IS
 | 
			
		||||
        A_TOTAL           OUT INTEGER,
 | 
			
		||||
        A_MENSUAL_CUR     OUT CUR_TYPE
 | 
			
		||||
    ) IS
 | 
			
		||||
        L_THIS_MONTH      VARCHAR2(4);
 | 
			
		||||
        L_THIS_YEAR       VARCHAR2(4);
 | 
			
		||||
        --L_THIS_MONTH      VARCHAR2(4);
 | 
			
		||||
        --L_THIS_YEAR       VARCHAR2(4);
 | 
			
		||||
        L_FIRSTDAY        DATE;
 | 
			
		||||
        L_DEPARTMENT_NAME VARCHAR2(100);
 | 
			
		||||
    BEGIN
 | 
			
		||||
        L_THIS_MONTH := TO_CHAR(SYSDATE,
 | 
			
		||||
        /*L_THIS_MONTH := TO_CHAR(SYSDATE,
 | 
			
		||||
                                'mm');
 | 
			
		||||
        L_THIS_YEAR  := TO_CHAR(SYSDATE,
 | 
			
		||||
                                'yyyy');
 | 
			
		||||
        L_FIRSTDAY   := TO_DATE(TO_CHAR(SYSDATE,
 | 
			
		||||
                                        'yyyy') || '-01-01 00:00:00',
 | 
			
		||||
                                'yyyy-mm-dd hh24:mi:ss');
 | 
			
		||||
                                'yyyy');*/
 | 
			
		||||
        L_FIRSTDAY := TO_DATE(TO_CHAR(SYSDATE,
 | 
			
		||||
                                      'yyyy') || '-01-01 00:00:00',
 | 
			
		||||
                              'yyyy-mm-dd hh24:mi:ss');
 | 
			
		||||
        -- <20><>ȡ<EFBFBD><C8A1><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>
 | 
			
		||||
        BEGIN
 | 
			
		||||
            SELECT DEPARTMENT_NAME
 | 
			
		||||
@@ -87,19 +87,25 @@ CREATE OR REPLACE PACKAGE BODY TELSALE_ARCHIEVEMENT_PKG IS
 | 
			
		||||
        WHERE CF.<2E>·<EFBFBD> = L_THIS_MONTH
 | 
			
		||||
          AND CF.<2E><><EFBFBD><EFBFBD> = L_THIS_YEAR
 | 
			
		||||
          AND <20><><EFBFBD>Ŵ<EFBFBD><C5B4><EFBFBD> = A_DEPARTMENT_CODE;*/
 | 
			
		||||
        SELECT dept.<2E><><EFBFBD>±<EFBFBD><C2B1><EFBFBD><EFBFBD><EFBFBD><EFBFBD><CDB8>
 | 
			
		||||
        SELECT round(dept.<2E><><EFBFBD>±<EFBFBD><C2B1><EFBFBD><EFBFBD><EFBFBD><EFBFBD><CDB8>,
 | 
			
		||||
                     2)
 | 
			
		||||
          INTO A_ATTACHING_RATE
 | 
			
		||||
          FROM desktop_archievement_admin.bi<62><69><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><CDB8><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>ͳ<EFBFBD>Ʊ<EFBFBD> dept
 | 
			
		||||
         WHERE dept.<2E><><EFBFBD><EFBFBD> = L_DEPARTMENT_NAME;
 | 
			
		||||
        --<2D><><EFBFBD><EFBFBD><EFBFBD><EFBFBD>
 | 
			
		||||
        SELECT DECODE(SUM(<28><><EFBFBD><EFBFBD><EFBFBD><EFBFBD>),
 | 
			
		||||
                      0,
 | 
			
		||||
                      0,
 | 
			
		||||
                      ROUND(SUM(<28><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>ۼ<EFBFBD>) / SUM(<28><><EFBFBD><EFBFBD><EFBFBD><EFBFBD>) * 100,
 | 
			
		||||
                            2))
 | 
			
		||||
        /*SELECT DECODE(SUM(<28><><EFBFBD><EFBFBD><EFBFBD><EFBFBD>),
 | 
			
		||||
                     0,
 | 
			
		||||
                     0,
 | 
			
		||||
                     ROUND(SUM(<28><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>ۼ<EFBFBD>) / SUM(<28><><EFBFBD><EFBFBD><EFBFBD><EFBFBD>) * 100,
 | 
			
		||||
                           2))
 | 
			
		||||
         INTO A_RENEWAL_RATE
 | 
			
		||||
         FROM <20><>ϯ<EFBFBD><CFAF><EFBFBD><EFBFBD>ͳ<EFBFBD><CDB3>
 | 
			
		||||
        WHERE <20><><EFBFBD><EFBFBD> = L_DEPARTMENT_NAME;*/
 | 
			
		||||
        SELECT round(t."<22><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>ʣ<EFBFBD>ȫ<EFBFBD>£<EFBFBD>(%)",
 | 
			
		||||
                     2)
 | 
			
		||||
          INTO A_RENEWAL_RATE
 | 
			
		||||
          FROM <EFBFBD><EFBFBD>ϯ<EFBFBD><EFBFBD><EFBFBD><EFBFBD>ͳ<EFBFBD><EFBFBD>
 | 
			
		||||
         WHERE <EFBFBD><EFBFBD><EFBFBD><EFBFBD> = L_DEPARTMENT_NAME;
 | 
			
		||||
          FROM BI<EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>¸<EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>ʸ<EFBFBD><EFBFBD>ٱ<EFBFBD> t
 | 
			
		||||
         WHERE t.<2E><><EFBFBD>β<EFBFBD><EFBFBD><EFBFBD> = L_DEPARTMENT_NAME;
 | 
			
		||||
        --<2D><>ҵ<EFBFBD><D2B5>
 | 
			
		||||
        SELECT ROUND(NVL(SUM(CF.<2E><><EFBFBD>ո<EFBFBD><D5B8>˿ͻ<CBBF><CDBB><EFBFBD><EFBFBD><EFBFBD> + CF.<2E><><EFBFBD><EFBFBD><EFBFBD>ںϱ<DABA><CFB1><EFBFBD>),
 | 
			
		||||
                         0),
 | 
			
		||||
@@ -141,6 +147,7 @@ CREATE OR REPLACE PACKAGE BODY TELSALE_ARCHIEVEMENT_PKG IS
 | 
			
		||||
        l_this_month  VARCHAR2(4);
 | 
			
		||||
        l_this_year   VARCHAR2(4);
 | 
			
		||||
        l_firstday    DATE;
 | 
			
		||||
        l_rownum      INTEGER;
 | 
			
		||||
    BEGIN
 | 
			
		||||
        --<2D><>ѯ<EFBFBD><D1AF>ϯ<EFBFBD><CFAF><EFBFBD>ƣ<EFBFBD><C6A3><EFBFBD>֤<EFBFBD><D6A4><EFBFBD><EFBFBD>
 | 
			
		||||
        BEGIN
 | 
			
		||||
@@ -172,28 +179,46 @@ CREATE OR REPLACE PACKAGE BODY TELSALE_ARCHIEVEMENT_PKG IS
 | 
			
		||||
           AND cf.<2E><><EFBFBD><EFBFBD> = l_this_year;
 | 
			
		||||
    
 | 
			
		||||
        --<2D><><EFBFBD><CDB8>
 | 
			
		||||
        SELECT decode(nvl(SUM(cf.<2E><><EFBFBD>ո<EFBFBD><D5B8>˿ͻ<CBBF><CDBB><EFBFBD><EFBFBD><EFBFBD>),
 | 
			
		||||
                          0),
 | 
			
		||||
                      0,
 | 
			
		||||
                      0,
 | 
			
		||||
                      round(SUM(cf.<2E><><EFBFBD><EFBFBD><EFBFBD>ںϱ<DABA><CFB1><EFBFBD>) / SUM(cf.<2E><><EFBFBD>ո<EFBFBD><D5B8>˿ͻ<CBBF><CDBB><EFBFBD><EFBFBD><EFBFBD>) * 100,
 | 
			
		||||
                            2))
 | 
			
		||||
          INTO a_attaching_rate
 | 
			
		||||
          FROM <20><>ϯ<EFBFBD><CFAF><EFBFBD><EFBFBD>ÿ<EFBFBD>ձ<EFBFBD><D5B1><EFBFBD> cf
 | 
			
		||||
         WHERE cf.<2E><>ϯ<EFBFBD><CFAF><EFBFBD><EFBFBD> = a_caller_code
 | 
			
		||||
           AND cf.<2E><><EFBFBD><EFBFBD> = l_this_year
 | 
			
		||||
           AND cf.<2E>·<EFBFBD> = l_this_month;
 | 
			
		||||
        SELECT rownum,
 | 
			
		||||
               round(nvl(t.<2E><><EFBFBD>±<EFBFBD><C2B1><EFBFBD><EFBFBD><EFBFBD><EFBFBD><CDB8>,
 | 
			
		||||
                         0),
 | 
			
		||||
                     2)
 | 
			
		||||
          INTO l_rownum,
 | 
			
		||||
               a_attaching_rate
 | 
			
		||||
          FROM BI<42><49><EFBFBD><EFBFBD><EFBFBD><EFBFBD>ϯ<EFBFBD><CFAF><EFBFBD><EFBFBD><EFBFBD><EFBFBD>ͳ<CDB8>Ʊ<EFBFBD> t
 | 
			
		||||
         WHERE t.<2E><>ϯ<EFBFBD><CFAF><EFBFBD><EFBFBD> = l_caller_name
 | 
			
		||||
           AND rownum = 1;
 | 
			
		||||
        /*SELECT decode(nvl(SUM(cf.<2E><><EFBFBD>ո<EFBFBD><D5B8>˿ͻ<CBBF><CDBB><EFBFBD><EFBFBD><EFBFBD>),
 | 
			
		||||
                         0),
 | 
			
		||||
                     0,
 | 
			
		||||
                     0,
 | 
			
		||||
                     round(SUM(cf.<2E><><EFBFBD><EFBFBD><EFBFBD>ںϱ<DABA><CFB1><EFBFBD>) / SUM(cf.<2E><><EFBFBD>ո<EFBFBD><D5B8>˿ͻ<CBBF><CDBB><EFBFBD><EFBFBD><EFBFBD>) * 100,
 | 
			
		||||
                           2))
 | 
			
		||||
         INTO a_attaching_rate
 | 
			
		||||
         FROM <20><>ϯ<EFBFBD><CFAF><EFBFBD><EFBFBD>ÿ<EFBFBD>ձ<EFBFBD><D5B1><EFBFBD> cf
 | 
			
		||||
        WHERE cf.<2E><>ϯ<EFBFBD><CFAF><EFBFBD><EFBFBD> = a_caller_code
 | 
			
		||||
          AND cf.<2E><><EFBFBD><EFBFBD> = l_this_year
 | 
			
		||||
          AND cf.<2E>·<EFBFBD> = l_this_month;*/
 | 
			
		||||
    
 | 
			
		||||
        --<2D><><EFBFBD><EFBFBD><EFBFBD><EFBFBD>
 | 
			
		||||
        SELECT decode(nvl(SUM(xb.<2E><><EFBFBD><EFBFBD><EFBFBD><EFBFBD>),
 | 
			
		||||
                          0),
 | 
			
		||||
                      0,
 | 
			
		||||
                      0,
 | 
			
		||||
                      round(SUM(xb.<2E><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>ۼ<EFBFBD>) / SUM(xb.<2E><><EFBFBD><EFBFBD><EFBFBD><EFBFBD>) * 100,
 | 
			
		||||
                            2)) xbl
 | 
			
		||||
          INTO a_renewal_rate
 | 
			
		||||
          FROM <20><>ϯ<EFBFBD><CFAF><EFBFBD><EFBFBD>ͳ<EFBFBD><CDB3> xb
 | 
			
		||||
         WHERE xb.<2E><>ϯ<EFBFBD><CFAF><EFBFBD><EFBFBD> = a_caller_code;
 | 
			
		||||
        /*SELECT decode(nvl(SUM(xb.<2E><><EFBFBD><EFBFBD><EFBFBD><EFBFBD>),
 | 
			
		||||
                         0),
 | 
			
		||||
                     0,
 | 
			
		||||
                     0,
 | 
			
		||||
                     round(SUM(xb.<2E><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>ۼ<EFBFBD>) / SUM(xb.<2E><><EFBFBD><EFBFBD><EFBFBD><EFBFBD>) * 100,
 | 
			
		||||
                           2)) xbl
 | 
			
		||||
         INTO a_renewal_rate
 | 
			
		||||
         FROM <20><>ϯ<EFBFBD><CFAF><EFBFBD><EFBFBD>ͳ<EFBFBD><CDB3> xb
 | 
			
		||||
        WHERE xb.<2E><>ϯ<EFBFBD><CFAF><EFBFBD><EFBFBD> = a_caller_code;*/
 | 
			
		||||
        SELECT rownum,
 | 
			
		||||
               round(nvl(t.<2E><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>ȫ<EFBFBD><C8AB>,
 | 
			
		||||
                         0),
 | 
			
		||||
                     2)
 | 
			
		||||
          INTO l_rownum,
 | 
			
		||||
               a_renewal_rate
 | 
			
		||||
          FROM BI<42><49>ϯ<EFBFBD><CFAF><EFBFBD><EFBFBD><EFBFBD><EFBFBD>ͳ<EFBFBD>Ʊ<EFBFBD> t
 | 
			
		||||
         WHERE t.<2E><><EFBFBD><EFBFBD><EFBFBD><EFBFBD> = l_caller_name
 | 
			
		||||
           AND rownum = 1;
 | 
			
		||||
    
 | 
			
		||||
        --ÿ<><C3BF>ҵ<EFBFBD><D2B5>
 | 
			
		||||
        OPEN A_MENSUAL_CUR FOR
 | 
			
		||||
@@ -237,38 +262,54 @@ CREATE OR REPLACE PACKAGE BODY TELSALE_ARCHIEVEMENT_PKG IS
 | 
			
		||||
        END;
 | 
			
		||||
        -- <20><><EFBFBD><EFBFBD><EFBFBD>ں<EFBFBD><DABA><EFBFBD><EFBFBD><EFBFBD><EFBFBD>а<EFBFBD>
 | 
			
		||||
        OPEN A_ATTACHING_RANKING_LIST FOR
 | 
			
		||||
            SELECT ROWNUM,
 | 
			
		||||
                   <20><>ϯ<EFBFBD><CFAF><EFBFBD><EFBFBD>   AS CALLER_NAME,
 | 
			
		||||
                   <EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> AS ATTACHING_RATE
 | 
			
		||||
              FROM (SELECT <EFBFBD><EFBFBD>ϯ<EFBFBD><EFBFBD><EFBFBD><EFBFBD>,
 | 
			
		||||
                           ROUND(DECODE(nvl(SUM(<28><><EFBFBD>ո<EFBFBD><D5B8>˿ͻ<CBBF><EFBFBD><EFBFBD><EFBFBD><EFBFBD>),
 | 
			
		||||
                                            0),
 | 
			
		||||
                                        0,
 | 
			
		||||
                                        0,
 | 
			
		||||
                                        (SUM(<28><><EFBFBD><EFBFBD><EFBFBD>ںϱ<DABA><CFB1><EFBFBD>) / SUM(<EFBFBD><EFBFBD><EFBFBD>ո<EFBFBD><EFBFBD>˿ͻ<EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>)) * 100),
 | 
			
		||||
                                 2) <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><CDB8>
 | 
			
		||||
                      FROM <20><>ϯ<EFBFBD><CFAF><EFBFBD><EFBFBD>ÿ<EFBFBD>ձ<EFBFBD><D5B1><EFBFBD>
 | 
			
		||||
                     WHERE <20>·<EFBFBD> = A_MONTH
 | 
			
		||||
                       AND <20><><EFBFBD><EFBFBD> = A_YEAR
 | 
			
		||||
                       AND <20><><EFBFBD>Ŵ<EFBFBD><C5B4><EFBFBD> = A_DEPARTMENT_CODE
 | 
			
		||||
                     GROUP BY <20><>ϯ<EFBFBD><CFAF><EFBFBD><EFBFBD>
 | 
			
		||||
                     ORDER BY <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><CDB8> DESC);
 | 
			
		||||
            SELECT rownum,
 | 
			
		||||
                   paihang.<EFBFBD><EFBFBD>ϯ<EFBFBD><EFBFBD><EFBFBD><EFBFBD> AS caller_name,
 | 
			
		||||
                   paihang.attaching_rate
 | 
			
		||||
              FROM (SELECT DISTINCT *
 | 
			
		||||
                      FROM (SELECT t.<2E><>ϯ<EFBFBD><EFBFBD><EFBFBD><EFBFBD>,
 | 
			
		||||
                                   round(t.<2E><><EFBFBD>±<EFBFBD><C2B1><EFBFBD><EFBFBD><EFBFBD><EFBFBD><CDB8>,
 | 
			
		||||
                                         2) attaching_rate,
 | 
			
		||||
                                   zuoxi.department_name
 | 
			
		||||
                              FROM BI<42><49><EFBFBD><EFBFBD><EFBFBD><EFBFBD>ϯ<EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>ͳ<EFBFBD>Ʊ<EFBFBD> t,
 | 
			
		||||
                                   (SELECT DISTINCT t.saler_code,
 | 
			
		||||
                                                    t.saler_name,
 | 
			
		||||
                                                    t.team_code,
 | 
			
		||||
                                                    team.team,
 | 
			
		||||
                                                    bm.department_name
 | 
			
		||||
                                      FROM tele_saler      t,
 | 
			
		||||
                                           tele_saler_team team,
 | 
			
		||||
                                           idst0.bm_t      bm
 | 
			
		||||
                                     WHERE t.team_code = team.team_code
 | 
			
		||||
                                       AND team.department_code = bm.department_code
 | 
			
		||||
                                       AND bm.department_name = L_DEPARTMENT_NAME) zuoxi
 | 
			
		||||
                             WHERE t.<2E><>ϯ<EFBFBD><CFAF><EFBFBD><EFBFBD> = zuoxi.saler_name) st
 | 
			
		||||
                     ORDER BY st.department_name,
 | 
			
		||||
                              st.attaching_rate DESC) paihang;
 | 
			
		||||
        -- <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>а<EFBFBD>
 | 
			
		||||
        OPEN A_RENEWAL_RANKING_LIST FOR
 | 
			
		||||
            SELECT ROWNUM,
 | 
			
		||||
                   <20><>ϯ<EFBFBD><EFBFBD><EFBFBD><EFBFBD> AS CALLER_NAME,
 | 
			
		||||
                   <EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>   AS RENEWAL_RATE
 | 
			
		||||
              FROM (SELECT <EFBFBD><EFBFBD>ϯ<EFBFBD><EFBFBD><EFBFBD><EFBFBD>,
 | 
			
		||||
                           decode(nvl(SUM(xb.<2E><><EFBFBD><EFBFBD><EFBFBD><EFBFBD>),
 | 
			
		||||
                                      0),
 | 
			
		||||
                                  0,
 | 
			
		||||
                                  0,
 | 
			
		||||
                                  round(SUM(xb.<2E><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>ۼ<EFBFBD>) / SUM(xb.<2E><><EFBFBD><EFBFBD><EFBFBD><EFBFBD>) * 100,
 | 
			
		||||
                                        2)) <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD>
 | 
			
		||||
                      FROM <20><>ϯ<EFBFBD><CFAF><EFBFBD><EFBFBD>ͳ<EFBFBD><CDB3> XB
 | 
			
		||||
                     WHERE XB.<2E><><EFBFBD><EFBFBD> = L_DEPARTMENT_NAME
 | 
			
		||||
                     GROUP BY <20><>ϯ<EFBFBD><CFAF><EFBFBD><EFBFBD>
 | 
			
		||||
                     ORDER BY <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD> DESC);
 | 
			
		||||
            SELECT rownum,
 | 
			
		||||
                   paihang.<EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> AS CALLER_NAME,
 | 
			
		||||
                   paihang.xbl    AS RENEWAL_RATE
 | 
			
		||||
              FROM (SELECT DISTINCT *
 | 
			
		||||
                      FROM (SELECT t.<2E><><EFBFBD><EFBFBD><EFBFBD><EFBFBD>,
 | 
			
		||||
                                   round(t.<2E><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>ȫ<EFBFBD><C8AB>,
 | 
			
		||||
                                         2) xbl,
 | 
			
		||||
                                   zuoxi.department_name
 | 
			
		||||
                              FROM BI<42><49>ϯ<EFBFBD><CFAF><EFBFBD><EFBFBD><EFBFBD><EFBFBD>ͳ<EFBFBD>Ʊ<EFBFBD> t,
 | 
			
		||||
                                   (SELECT DISTINCT t.saler_code,
 | 
			
		||||
                                                    t.saler_name,
 | 
			
		||||
                                                    t.team_code,
 | 
			
		||||
                                                    team.team,
 | 
			
		||||
                                                    bm.department_name
 | 
			
		||||
                                      FROM tele_saler      t,
 | 
			
		||||
                                           tele_saler_team team,
 | 
			
		||||
                                           idst0.bm_t      bm
 | 
			
		||||
                                     WHERE t.team_code = team.team_code
 | 
			
		||||
                                       AND team.department_code = bm.department_code
 | 
			
		||||
                                       AND bm.department_name = L_DEPARTMENT_NAME) zuoxi
 | 
			
		||||
                             WHERE t.<2E><><EFBFBD><EFBFBD><EFBFBD><EFBFBD> = zuoxi.saler_name) xb
 | 
			
		||||
                     ORDER BY xb.department_name,
 | 
			
		||||
                              xb.xbl DESC) paihang;
 | 
			
		||||
    END;
 | 
			
		||||
BEGIN
 | 
			
		||||
    NULL;
 | 
			
		||||
 
 | 
			
		||||
		Reference in New Issue
	
	Block a user