[英]Rails: Search DB for part of datetime
我有个问题。 在我的应用程序中,我有一个包含数据的列表。 此数据包括 datetime_utc 列。 还有一个允许用户搜索日期时间字符串的搜索栏,但搜索栏现在需要精确输入,因此例如这些输入返回结果:
2023-01-01 02:00:00
2023-01-01 02:00
2023-01-01 02
只要输入字符串以有效的日期时间格式开头。 例如,我想要的是仅查找给定时间,例如:
02:00
这应该返回时间为02:00:00
的所有数据作为datetime_utc
值。 现在这是我的代码:
data = data.where(datetime_utc: "#{params[:search]}") if params[:search] && params[:search] != ''
我试过这样的事情:
data = data.where("to_char(datetime_utc, 'YYYY-MM-DD HH24:MI:SS') LIKE ?": "%#{params[:search]}%") if params[:search] && params[:search] != ''
但这给了我错误:
PG::UndefinedColumn: ERROR: column candlesticks.to_char(datetime_utc, 'YYYY-MM-DD HH24:MI:SS') LIKE ? does not exist
所以我知道 Postgres 首先将给定的输入字符串格式化为日期时间格式,但我不能这样做,它崩溃了。
一定有办法让它正常工作吗?
Rails 正在考虑"to_char(datetime_utc, 'YYYY-MM-DD HH24:MI:SS') LIKE?"
作为列名,因为使用的格式不正确
您需要将查询更改为(注意:
被替换为,
)
data = data.where("to_char(datetime_utc, 'YYYY-MM-DD HH24:MI:SS') LIKE ?", "%#{params[:search]}%") if params[:search] && params[:search] != ''
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.