联系及时率

CREATE OR REPLACE PROCEDURE P_MDJ_1001066_TO_ZW(I_SPAN IN VARCHAR2, --无用参数可输入任意值
                                                O_SQL  OUT VARCHAR2,
                                                O_FILE OUT VARCHAR2)

 AS
  O_RET          NUMBER;
  PROCEDURE_NAME VARCHAR2(200);
  V_SQLECODE     VARCHAR2(50);
  V_SQLERRM      VARCHAR2(500);
  V_FILENAME     VARCHAR2(100);
  V_SQL          VARCHAR2(4000);
BEGIN
  PROCEDURE_NAME:=GETEXEC_PROCEDURE_NAME();
  O_RET := 1;

  execute immediate 'truncate table ICDPUB.T_MDJ_1001066_TO_ZW';

  INSERT INTO ICDPUB.T_MDJ_1001066_TO_ZW
  SELECT B.SERIALNO 流水号,
         CI.ORGANAME 地市名称,
         B.AREAID 小区编码,
         B.FIXMAN 维护员,
         A.CALLERNO 主叫号码,
         A.CALLEDNO 被叫号码,
         CASE WHEN A.ISPROCESSED IS NULL THEN '未呼出'
              WHEN A.ISPROCESSED = '0' THEN '呼出失败'
              ELSE '呼出成功' END 首次呼出是否成功,
         A.REMARK 首次呼出失败原因,
         A.FIRSTCONTACTSTARTTIME 首次联系时间,
         A.LASTCONTACTSTARTTIME 最后一次联系时间,
         A.CONTACTDURATION 首次通话时长,
         CASE WHEN A.FIRSTCONTACTSTARTTIME IS NULL THEN '否'
              WHEN (A.FIRSTCONTACTSTARTTIME - B.ARRIVETIME1) * 24 > 1 THEN '否'
              ELSE '是' END 是否1小时内联系用户,
         CASE WHEN A.FIRSTCONTACTSTARTTIME IS NULL THEN '否'
              WHEN (A.FIRSTCONTACTSTARTTIME - B.ARRIVETIME2) * 24 > 3 THEN '否'
              ELSE '是' END 是否3小时内联系用户,
         A.CALLCOUNT 本流水号累计联系用户次数
     FROM (SELECT T.SUBSNUMBER,MAX(CASE WHEN T.RN=1 THEN T.ISPROCESSED END) ISPROCESSED,MIN(T.CONTACTSTARTTIME) FIRSTCONTACTSTARTTIME,
                  MAX(T.CONTACTSTARTTIME) LASTCONTACTSTARTTIME,MAX(CASE WHEN RN=1 THEN T.CALLERNO END) CALLERNO,
                  MAX(CASE WHEN RN=1 THEN T.CALLEDNO END) CALLEDNO,MAX(CASE WHEN RN=1 THEN T.CONTACTDURATION END) CONTACTDURATION,
                  MAX(CASE WHEN RN=1 THEN T.REMARK END) REMARK,COUNT(T.SUBSNUMBER) CALLCOUNT --一张工单有多次呼叫,按工单流水分组,取第一次呼叫用户的记录
                  FROM
               (SELECT CD.SUBSNUMBER,            --工单流水号
                       CD.ISPROCESSED,			 --是否呼叫成功
                       CD.CONTACTSTARTTIME,		 --联系时间
                       CD.CALLERNO,				 --主叫号码
                       CD.CALLEDNO,				 --被叫号码
                       CD.CONTACTDURATION,		 --呼叫时长
                       CD.REMARK,				 --呼叫备注(失败原因)
                       ROW_NUMBER() OVER(PARTITION BY CD.SUBSNUMBER ORDER BY CD.CONTACTSTARTTIME) RN
                  FROM ICDPUB.T_CCT_CONTACTDETAIL CD
                 WHERE CD.CONTACTMODEID = '19'
                  AND CD.CONTACTSTARTTIME >= TRUNC(SYSDATE)-11
                  AND CD.CONTACTSTARTTIME < TRUNC(SYSDATE)
                  ) T GROUP BY T.SUBSNUMBER
           ) A,  --表A,从呼叫用户的表里获取呼叫信息

          (SELECT SERIALNO,  --工单流水号
                  CASE
                    WHEN TO_CHAR(CREATIONTIME, 'hh24') < 9 THEN
                     TRUNC(CREATIONTIME) + 9 / 24 --9点前下派工单,下派时间算作9点
                    WHEN TO_CHAR(CREATIONTIME, 'hh24') >= 18 THEN
                     TRUNC(CREATIONTIME + 1) + 9 / 24 --18点后下派的工单,下派时间算作第二天9点
                    WHEN TO_CHAR(CREATIONTIME,'HH24') >17 AND TO_CHAR(CREATIONTIME,'HH24') <18 THEN
                     TRUNC(CREATIONTIME + 1) + 9 / 24 - (CREATIONTIME - TRUNC(CREATIONTIME)-17/24) --17至18点间的工单,下派时间为第二天9点减去工单在17至18点之间已运行的时间
                    ELSE
                     CREATIONTIME --非以上时间段则为系统记录的工单下派时间
                  END AS ARRIVETIME1,  --1小时联系及时率的工单下派时间(将系统记录的下派时间处理为正常上班时间)
                  CASE
                    WHEN TO_CHAR(CREATIONTIME, 'hh24') < 8.5 THEN
                     TRUNC(CREATIONTIME) + 8.5 / 24
                    WHEN TO_CHAR(CREATIONTIME, 'hh24') >= 18 THEN
                     TRUNC(CREATIONTIME + 1) + 8.5 / 24
                    WHEN TO_CHAR(CREATIONTIME, 'hh24') >15 AND TO_CHAR(CREATIONTIME, 'hh24') <18 THEN
                     TRUNC(CREATIONTIME + 1) + 8.5 / 24 - (CREATIONTIME - TRUNC(CREATIONTIME)-15/24)
                    ELSE
                     CREATIONTIME
                  END AS ARRIVETIME2,  --3小时联系及时率的工单下派时间(将系统记录的下派时间处理为正常上班时间)
                  CREATIONTIME, --工单下派时间
                  SERVICECITY,  --地市ID
                  FIXMAN,		--装维人员
                  AREAID		--小区编码
             FROM (SELECT PP.SERIALNO,
                          MIN(PW.CREATIONTIME) CREATIONTIME,
                          MIN(PP.SERVICECITY) SERVICECITY,
                          MIN(PP.PUBDYNACHAR108) FIXMAN,
                          MIN(SR.SERVICEINFOCHAR165) AREAID
                     FROM ICDPUB.T_PBH_PROBLEMPROCESS  PP,
                          ICDPUB.T_PBH_PROBLEMWORKITEM PW,
                          ICDPUB.T_SR_SERVICEREQUEST   SR
                    WHERE PP.SRTYPEID LIKE '004001%'
                      AND PP.ARCHIVEDATE >= TRUNC(SYSDATE)-1
                      AND PP.ARCHIVEDATE < TRUNC(SYSDATE)
                      AND PP.SERIALNO = PW.SERIALNO
                      AND PW.NODENAME = '装维处理'
                      AND SR.SERVICEID = PP.SRID
                    GROUP BY PP.SERIALNO) --从工单记录表里获取装维系统环节的信息
           ) B,  --表B,从工单表里获取工单信息
          ICDPUB.T_UCP_CITYINFO CI
    WHERE B.SERIALNO = A.SUBSNUMBER(+)
      AND CI.ORGAID = B.SERVICECITY;
  COMMIT;
  O_RET := 2;

  --获取文件名称
  V_FILENAME := 'order_' || TO_CHAR(SYSDATE, 'yyyymmddhh24miss');
  V_SQL:='SELECT   SERIALNO             ,'||
         '         ORGANAME             ,'||
         '         AREAID               ,'||
         '         FIXMAN               ,'||
         '         CALLERNO             ,'||
         '         CALLEDNO             ,'||
         '         ISPROCESSED          ,'||
         '         REMARK               ,'||
         '         FIRSTCONTACTSTARTTIME,'||
         '         LASTCONTACTSTARTTIME ,'||
         '         CONTACTDURATION      ,'||
         '         CALLIN1HOUR          ,'||
         '         CALLIN3HOURS         ,'||
         '         CALLCOUNT            FROM ICDPUB.T_MDJ_1001066_TO_ZW';
  O_RET := 3;

  O_FILE := V_FILENAME;
  O_SQL  := V_SQL;

EXCEPTION
  WHEN OTHERS THEN
    ROLLBACK;
    O_RET      := 999;
    V_SQLECODE := SQLCODE;
    V_SQLERRM  := SUBSTR(SQLERRM, 1, 300);
    INSERT INTO ICDPUB.T_MDJ_ERRORLOG
    VALUES
      (SYSDATE,
       '',
       O_RET,
       V_SQLECODE,
       V_SQLERRM,
       '[FAIL]['||PROCEDURE_NAME||']');
    COMMIT;

END P_MDJ_1001066_TO_ZW;

编程技巧