0

我对 MySQL 数据库有这个查询:

Article.where('DAY( created_at ) = DAY( ? )', day)

我也尝试在 PostgreSQL 数据库中使用上面的查询,特别是我正在尝试这样的事情:

Article.where("DATE_PART('day', created_at) = DATE_PART('day', ?)", today)

但我得到了错误PGError: ERROR: function date_part(unknown, unknown) is not unique

为什么会出现这个错误?我以为我有文档的语法......

4

2 回答 2

2

看来today是一串图案YYYY-MM-DD。您可以只提取最右边的两个字符,而不是转换为日期然后提取一个数字。会更快更简单:

Article.where("date_part('day', created_at::date)::int
                        = right(?, 2)::int", today)

right()需要 PostgreSQL 9.1 或更高版本。在旧版本中,您可以替换:

... = substring(?, 9)

因为你想要字符 9 和 10。


这也应该有效:

Article.where("date_part('day', created_at::date)::int
                        = date_part('day', ?::date)", today)

请注意,您必须'2012-01-16'转换为date,而不是interval'2012-01-16'::interval将是胡说八道。

于 2012-01-16T23:10:16.087 回答
1

根据文档,有两个功能:

  • date_part(text, timestamp)
  • date_part(text, interval)

所以数据库不能选择你想要的。将第二个参数转换为时间戳,例如:

DATE_PART('day', created_at::interval) = DATE_PART('day', ?::interval)
于 2012-01-16T22:17:44.190 回答