0

我想在我的数据库中查询生日在开始日期和结束日期之间的人。该字段与数据库中的日期一起存储,因此需要选择周年而不考虑年份。我尝试使用提取之类的函数来获取日期和月份,但是当开始日期大于最后一天时,不显示任何记录。有没有人有没有存储过程的解决方案?

4

1 回答 1

2

如果要忽略年份,则需要提取月份和日期并分别比较:

  • 月份是开始月份,日期等于或大于开始日期
  • 月份大于开始月份且小于结束月份
  • 月份是结束月份,并且天数小于或等于结束日期

这会给你这个查询:

select * 
from (
    select 
        extract(month from people.birthdate) as birthmonth, 
        extract(day from people.birthdate) as birthday, 
        * 
    from people) a
where a.birthmonth = :startmonth and a.birthday >= :startday
or a.birthmonth > :startmonth and a.birthmonth < :endmonth
or a.birthmonth = :endmonth and a.birthday <= :endday

请注意,为了清楚起见,我使用了命名参数,即使 Firebird 本身没有它们。您需要将其替换为位置参数,除非您的连接库可以为您执行此操作。

如果您想提供一个实际的开始和结束日期作为参数,那么您可能需要做一些额外的工作。

于 2017-02-10T09:36:58.323 回答