Oracle中的重叠功能 [英] Overlap function in Oracle

查看:84
本文介绍了Oracle中的重叠功能的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着小编来一起学习吧!

问题描述

我正在编写一个软件包来学习Oracle.我想创建一个OVERLAP函数,该函数检查两个日期范围是否相互重叠.

I'm writing a package to learn Oracle. I want to create an OVERLAP function that checks if two date ranges overlap each other.

  FUNCTION OVERLAP(p_START_DATE_1 DATE, p_END_DATE_1 DATE,
   p_START_DATE_2 DATE, p_END_DATE_2 DATE) RETURN VARCHAR2 AS

   lv_RESULT VARCHAR2(1);
  BEGIN 

   lv_RESULT := SELECT 'T' AS overlap FROM dual
       WHERE (p_START_DATE_1, p_END_DATE_1) overlaps (p_START_DATE_2, p_END_DATE_2);

   IF (lv_RESULT = 'T')
     RETURN 'T';

   RETURN 'N';

  END OVERLAP;

我试图执行我的功能,但出现错误ORA-04063: package body 'XYZ' contains errors ...

I tried to execute my function, but getting an error ORA-04063: package body 'XYZ' contains errors...

SELECT KP_XYZ_PACKAGE_SQL.OVERLAP(
       TO_DATE('01/01/2014', 'DD/MM/YYYY'),
       TO_DATE('01/12/2014', 'DD/MM/YYYY'),
       TO_DATE('01/02/2014', 'DD/MM/YYYY'),
       TO_DATE('01/05/2014', 'DD/MM/YYYY'))
FROM DUAL;

我认为SELECT可以正常工作.但是这里出现错误(我想):lv_RESULT := SELECT....为什么?

I think SELECT works fine. But the error occurs (I suppose) here: lv_RESULT := SELECT.... Why?

推荐答案

尝试一下:

CREATE OR REPLACE FUNCTION OVERLAP(p_START_DATE_1 DATE, p_END_DATE_1 DATE,
   p_START_DATE_2 DATE, p_END_DATE_2 DATE) RETURN VARCHAR2 AS

   lv_RESULT VARCHAR2(1);
  BEGIN 
       lv_RESULT := 'N';      

       SELECT 'T' into lv_RESULT FROM dual
           WHERE (p_START_DATE_1, p_END_DATE_1) overlaps (p_START_DATE_2, p_END_DATE_2);

   IF (lv_RESULT = 'T') THEN
     RETURN 'T';
   END IF;

   RETURN 'N';

  END OVERLAP;

IF语句也不完整-THEN和END IF丢失了,我现在已经添加了.

The IF statement was incomplete too - THEN and END IF were missing, which I have now added.

SELECT INTO语句的文档为 这里 .页面末尾有示例的链接.

The documentation for SELECT INTO statement is here. There are links to examples at the end of the page.

这篇关于Oracle中的重叠功能的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持IT屋!

查看全文
登录 关闭
扫码关注1秒登录
发送“验证码”获取 | 15天全站免登陆