我正在尝试编写SQL代码(使用SQL Developer)来检查一个人在过去6个月的保险期限内是否生日。

这是我的代码当前的样子。

SELECT DRIVER_KEY, CASE WHEN BDAY BETWEEN EFFDAY AND EXPDAY THEN 1 ELSE 0 END AS BDAYIND FROM (
    SELECT DISTINCT A.DRIVER_KEY
    , TO_CHAR(A.BIRTH_DATE,'mm/dd') AS BDAY
     , TO_CHAR(SUBSTR(A.EFFECTIVE_DATE_KEY,5,2)||'/'||SUBSTR(A.EFFECTIVE_DATE_KEY,7,2) ) AS EFFDAY
    , TO_CHAR(SUBSTR(A.EXPIRATION_DATE_KEY,5,2)||'/'||SUBSTR(A.EXPIRATION_DATE_KEY,7,2) ) AS EXPDAY
    FROM DRIVER_TABLE A
    );


它有效-只要期限不超过一年。但是,我的代码当前显示01/25不在09/19到03/19之间。如何解决此问题?

最佳答案

编辑:正如APC指出的那样,我的解决方案在leap年期间不起作用。我通常会删除此帖子,但已被选为该问题的答案。我更新了下面的代码,以使用Brian Leach解决方案中的年份逻辑而不是to_date字符串。请改用Brian或APC的答案。

这是我的带有任意日期的create语句:

create table DRIVER_TABLE
(
  BIRTH_DATE date,
  EFFECTIVE_DATE_KEY date,
  EXPIRATION_DATE_KEY date
  );

  insert into DRIVER_TABLE
  values(to_date('05/01/1980','MM/DD/YYYY'),
         to_date('11/01/2016','MM/DD/YYYY'),
         to_date('04/01/2017','MM/DD/YYYY'));


这是查询:

select case when BirthdayEFFYear between EFFECTIVE_DATE_KEY and EXPIRATION_DATE_KEY
              or BirthdayEXPYear between EFFECTIVE_DATE_KEY and EXPIRATION_DATE_KEY
              or to_number(EXPIRATION_DATE_KEY - EFFECTIVE_DATE_KEY) / 365 > 1
        then 1 else 0 end BDAYIND
from(
select add_months(BIRTH_DATE,12 * (extract(year from EFFECTIVE_DATE_KEY) - extract(year from BIRTH_DATE))) BirthdayEFFYear,
       add_months(BIRTH_DATE,12 * (extract(year from EXPIRATION_DATE_KEY) - extract(year from BIRTH_DATE))) BirthdayEXPYear,
       EFFECTIVE_DATE_KEY,EXPIRATION_DATE_KEY
from DRIVER_TABLE A
)


SQLFiddle

09-25 16:36