我一直试图在Postgres上复制这个Server查询:
MONTH(QC.ModifiedDate) >= Month(GETDATE())
AND YEAR(QC.ModifiedDate) >= YEAR((GETDATE()))最后,我得到了一个长而不太好看的查询。
EXTRACT(MONTH FROM QC.ModifiedDate) >= date_part('month', (SELECT current_timestamp)) AND EXTRACT(YEAR FROM QC.ModifiedDate) >= date_part('year', (SELECT current_timestamp));它似乎也不管用。有什么建议吗?
发布于 2021-02-21 16:29:45
如果要将TSQL查询的相同逻辑应用于PostgreSQL查询,则代码是正确的,尽管可以通过删除current_timestamp的内部SELECT来简化代码。
EXTRACT(MONTH FROM QC.ModifiedDate) >= date_part('month', current_timestamp)
AND
EXTRACT(YEAR FROM QC.ModifiedDate) >= date_part('year', current_timestamp)但如果逻辑是:
在当前月份及以后返回带有
ModifiedDate的所有行
那么它就更简单了:
QC.ModifiedDate >= date_trunc('month', current_timestamp)因为date_trunc('month', current_timestamp)返回当前月份第一天的时间戳。
发布于 2021-02-21 16:34:28
我能想到的最简单的形式:
select date_trunc('month', '03/12/2021'::date) >= date_trunc('month', current_date);
-- Where date_trunc yields:
select date_trunc('month', current_date);
date_trunc
------------------------
2021-02-01 00:00:00-08https://stackoverflow.com/questions/66304306
复制相似问题