postgresql - 错误:运算符不存在:没有时区的时间戳>整数)
问题描述
我正在使用 Rails 5.2 并传递一个日期参数。为了简化我的示例,请看下面的 sql 查询,它类似但简化了,因为它太复杂而无法与活动记录方法一起使用,所以我需要运行原始 sql..
sql = 'Select * FROM mytable WHERE created_at > #{@start_date_time}'
1)当我将参数传递给字符串或执行命令时,如何清理它们。
2) 我的日期应该采用什么格式?我试过 '2018-01-01 00:00:00.000' 和 '2018-01-01' 和两个错误。
代码:
sql =count_query(@start_date_time, sender_type, sender_id)
records_array = ActiveRecord::Base.connection.execute(sql)
错误
ActiveRecord::StatementInvalid (PG::UndefinedFunction:
ERROR: operator does not exist: timestamp without time zone > integer)
LINE 11: WHERE created_at > 2018-01-01
解决方案
WHERE created_at > '2018-01-01' 应该可以工作