查找大于使用hstore和rails的值

时间:2013-10-08 08:25:56

标签: ruby-on-rails ruby rails-postgresql pg hstore

我正在使用rails中的hstore和postgresql存储产品信息,包括产品的发布年份。现在,我希望能够查询在特定年份之前或之后发布的所有产品。我可以使用以下命令查询“data”hstore列中包含year字段的所有记录:

Product.where("data ? 'year'")

由于hstore,年份值存储为字符串。因此,我尝试将年份类型转换为整数,以便查找年份大于/小于X的记录:

Product.where("(data ? 'year')::int > 2011")

然而,这似乎不起作用,我总是得到一个空数组的结果作为回报。我究竟做错了什么?还有另一种方法吗?

1 个答案:

答案 0 :(得分:2)

我认为您正在寻找的运营商是->

所以,试试这个:where("(data -> 'year')::int > 2011")

(来自jO3w'评论)