我一直试图在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)返回当前月份第一天的时间戳。
https://stackoverflow.com/questions/66304306
复制相似问题