Oracle 自定义function笔记

最近项目中写做报表有一些特殊的需求,用到了function,此处留个笔记。

--判断任务是否有报工
  CREATE OR REPLACE FUNCTION WEATHER_DAILY_WORK(TWID IN INTEGER)
  RETURN INTEGER IS
  OUT_ISEXIT INTEGER;
BEGIN
  IF TWID IS NULL THEN
    RETURN 0;
  END IF;
  SELECT COUNT(1)
    INTO OUT_ISEXIT
    FROM TEST_BR_WORK TB, TEST_WORK_MANAG TW
   WHERE TB.ID = TW.TMW_TW_ID
     AND TB.TBR_MIANWORKID = TWID;
  RETURN OUT_ISEXIT;
END WEATHER_DAILY_WORK;  
/


--报表超链接 function
CREATE OR REPLACE FUNCTION GET_GRABTASK_IDS(GROUPNAME IN VARCHAR2,
                                              TASKTYPE  IN INTEGER,
                                              STARTTIME IN VARCHAR2,
                                              ENDTIME   IN VARCHAR2)
  RETURN VARCHAR2 AS
  OUT_PUT VARCHAR2(4000);
  OUT_NUM VARCHAR2(4000);
BEGIN
  OUT_PUT := ' SELECT wm_concat(S.MS_EAPS_ID)  FROM SNATCH_TASK S, V_PERSON_GROUP V, ' ||
             ' TEST_WORK T  WHERE S.MS_CREATER = V.LOGINNAME ' ||
             ' AND S.MS_EAPS_ID = T.ID ';
  IF GROUPNAME = 'all' THEN
    OUT_PUT := OUT_PUT ||
               ' AND V.GROUPNAME in (''功能一组'',''功能二组'',''功能三组'') ';
  ELSE
    OUT_PUT := OUT_PUT || ' AND V.GROUPNAME = ''' || GROUPNAME || '''';
  END IF;
  IF TASKTYPE = 1 THEN
    OUT_PUT := OUT_PUT || ' AND T.WK_PROCESS = ''已投产''';
  END IF;
  IF TASKTYPE = 2 THEN
    OUT_PUT := OUT_PUT || ' AND s.ms_state = ''已认领'' ' ||
               ' and S.MS_EAPS_ID in (SELECT DISTINCT (TB.TBR_MIANWORKID) FROM TEST_BR_WORK TB, TEST_WORK_MANAG TW ' ||
               ' WHERE TB.ID = TW.TMW_TW_ID)';
  END IF;
  IF TASKTYPE = 3 THEN
    OUT_PUT := OUT_PUT || ' AND s.ms_state = ''已认领'' ' ||
               ' and S.MS_EAPS_ID not in (SELECT DISTINCT (TB.TBR_MIANWORKID) FROM TEST_BR_WORK TB, TEST_WORK_MANAG TW ' ||
               ' WHERE TB.ID = TW.TMW_TW_ID)';
  END IF;
  IF TASKTYPE = 4 THEN
    OUT_PUT := OUT_PUT || ' AND s.ms_state = ''已召回''';
  END IF;
  IF TASKTYPE = 5 THEN
    OUT_PUT := OUT_PUT || ' AND s.ms_state = ''未开始''';
  END IF;
  IF TASKTYPE = 6 THEN
    OUT_PUT := OUT_PUT || ' AND s.ms_state = ''已撤除''';
  END IF;
  IF STARTTIME IS NOT NULL THEN
    OUT_PUT := OUT_PUT ||
               ' AND TO_CHAR(S.MS_PRIVATE_TIME, ''yyyy-mm-dd'') >= ''' ||
               STARTTIME || '''';
  END IF;
  IF ENDTIME IS NOT NULL THEN
    OUT_PUT := OUT_PUT ||
               ' AND TO_CHAR(S.MS_PRIVATE_TIME, ''yyyy-mm-dd'') <= ''' ||
               ENDTIME || '''';
  END IF;
  EXECUTE IMMEDIATE OUT_PUT
    INTO OUT_NUM;
  RETURN OUT_NUM;
END GET_GRABTASK_IDS; 
/


--调用函数返回至 并用逗号分成列
SELECT REGEXP_SUBSTR(C.A, '[^,]+', 1, LEVEL)
  FROM (SELECT MAX(GET_GRABTASK_IDS(?,?,?,?)) A
          FROM DUAL) C
CONNECT BY LEVEL < LENGTH(C.A)  

注:在linux sqlplus中执行function时,一定记得在最后写 / 不然是无法执行的!!!

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

Java小技巧

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值