PostgreSQL:尝试运行删除查询时,语法错误在“ 14”或附近

时间:2020-08-26 09:40:32

标签: postgresql sql-delete

第一个问题在这里!

所以我有一张桌子,上面有这样的行:

created_at TIMESTAMP DEFAULT CURRENT_TIMESTAMP

我想运行一个查询,以删除表中早于14天的所有数据。

这是我的查询:

DELETE FROM customers WHERE timestamp < NOW() - INTERVAL 14 DAY;

这是错误:语法错误在“ 14”或附近

任何人都知道为什么这行不通和/或我如何实现我的目标?

非常感谢!

3 个答案:

答案 0 :(得分:1)

间隔值必须用引号引起来

DELETE FROM customers WHERE created_at < NOW() - INTERVAL '14 DAYS';

请参见the doc

答案 1 :(得分:0)

DELETE FROM customers WHERE created_at < NOW() - INTERVAL '14 DAY'; 

答案 2 :(得分:0)

现有答案的另一种变体(可能更容易记住):

DELETE FROM customers WHERE timestamp < NOW() - '14 days'::interval;