微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

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

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

一个问题在这里

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

created_at TIMESTAMP DEFAULT CURRENT_TIMESTAMP

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

这是我的查询

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

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

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

非常感谢!

解决方法

间隔值必须用引号引起来

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

请参见the doc

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

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

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

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。