MySQL查询生日通知的Hibernate或Native查询

时间:2018-04-22 16:40:17

标签: mysql hibernate hql nativequery hibernate-native-query

我有一个用户表,其中包含与用户相关的各种详细信息,如ID,名称,专业,电子邮件,移动设备,DOB。我想编写一个查询,该查询应该获取明天过生日的用户。

使用MySQL查询:

SELECT * 
FROM  user 
WHERE  DATE_ADD(DOB, INTERVAL YEAR(CURDATE())-YEAR(DOB) + IF(DAYOFYEAR(CURDATE()) > DAYOFYEAR(DOB),1,0) YEAR) BETWEEN CURDATE() AND DATE_ADD(CURDATE(), INTERVAL 1 DAY);

结果:

Eg: ID  | Name  | Profession    | Email         | Mobile    | DOB
    1   | A     |   IT          | a@gmail.com   | 123       | 1987-04-23
    2   | B     |   Student     | b@gmail.com   | 234       | 1987-05-23
    3   | C     |   Actor       | c@gmail.com   | 456       | 1987-06-23

Output: 1   | A     |   IT          | a@gmail.com   | 123       | 1987-04-23

在编写Hibernate或Native查询方面需要帮助。

-Thanks。

1 个答案:

答案 0 :(得分:0)

您可以将DATE_ADD()INTERVAL一起使用。看下面的查询:

SELECT
    *
FROM
    user
where
    date(DOB)= date(
        DATE_ADD(
            now(),
            INTERVAL 1 DAY
        )
    ) and month(DOB)= month(
    DATE_ADD(
        now(),
        INTERVAL 1 DAY
    )
) ;