You need to enable JavaScript to run this app.
最新活动
大模型
产品
解决方案
定价
生态与合作
支持与服务
开发者
了解我们

PostgreSQL中如何构造查询语句筛选出生于周日或每月13日的人员

嘿,我来帮你搞定这两个PostgreSQL查询问题!这其实用内置的日期函数就能轻松解决,我给你一步步拆解:

查询所有出生在周日的人员

PostgreSQL里有个非常实用的EXTRACT()函数,可以从日期中提取特定的部分。对于星期几,我们用DOW(Day Of Week)参数——它的取值是0到6,其中0代表周日,1是周一,以此类推直到6是周六。

直接用这个条件筛选就行,假设你的表叫people,生日字段是birth_date,查询语句如下:

SELECT *
FROM people
WHERE EXTRACT(DOW FROM birth_date) = 0;

如果你偏好更直观的文本判断,也可以用TO_CHAR()函数把日期转成星期的缩写,比如:

SELECT *
FROM people
WHERE TO_CHAR(birth_date, 'Dy') = 'Sun';

不过要注意,这个方法依赖数据库的本地化设置,如果你的数据库是中文环境,可能需要写成'周日',所以更稳妥的还是用EXTRACT(DOW...)的方式。

查询所有出生在每月13日的人员

这个更简单,同样用EXTRACT()函数提取日期中的“日”部分,判断是否等于13即可:

SELECT *
FROM people
WHERE EXTRACT(DAY FROM birth_date) = 13;

当然,如果你想把两个条件合并,一次性查出“周日出生”或者“每月13日出生”的人员,用OR连接就行:

SELECT *
FROM people
WHERE EXTRACT(DOW FROM birth_date) = 0
   OR EXTRACT(DAY FROM birth_date) = 13;

小提醒

如果你的生日字段是字符串类型(不建议这么存,最好用DATETIMESTAMP类型),需要先把它转换成日期格式再使用函数,比如:

SELECT *
FROM people
WHERE EXTRACT(DOW FROM TO_DATE(birth_str, 'YYYY-MM-DD')) = 0;

这里的'YYYY-MM-DD'要对应你字符串日期的格式,比如如果是'MM/DD/YYYY'就改成这个。

内容的提问来源于stack exchange,提问作者antekkalafior

火山引擎 最新活动