【发布时间】:2016-07-16 10:14:55
【问题描述】:
我正在使用ransack gem 在 Rails 应用程序中进行搜索。我需要在User 表中搜索email_ids 的数组。
参考this洗劫时的问题,我按照步骤将其添加到初始化文件夹ransack.rb
Ransack.configure do |config|
{
contained_within_array: :contained_within,
contained_within_or_equals_array: :contained_within_or_equals,
contains_array: :contains,
contains_or_equals_array: :contains_or_equals,
overlap_array: :overlap
}.each do |rp, ap|
config.add_predicate rp, arel_predicate: ap, wants_array: true
end
end
在 Rails 控制台中,如果我这样做:
a = User.search(email_contains_array: ['priti@gmail.com'])
它会产生这样的 sql:
"SELECT \"users\".* FROM \"users\" WHERE \"users\".\"deleted_at\" IS NULL AND (\"users\".\"email\" >> '---\n- priti@gmail.com\n')"
并给出如下错误:
User Load (1.8ms) SELECT "users".* FROM "users" WHERE "users"."deleted_at" IS NULL AND ("users"."email" >> '---
- priti@gmail.com
')
ActiveRecord::StatementInvalid: PG::UndefinedFunction: ERROR: operator does not exist: character varying >> unknown
LINE 1: ...RE "users"."deleted_at" IS NULL AND ("users"."email" >> '---
^
HINT: No operator matches the given name and argument type(s). You might need to add explicit type casts.
: SELECT "users".* FROM "users" WHERE "users"."deleted_at" IS NULL AND ("users"."email" >> '---
- priti@gmail.com
')
预期是这个查询:
SELECT "users".* FROM "users" WHERE ("users"."roles" @> '{"3","4"}')
我做错了什么?
【问题讨论】:
标签: ruby-on-rails ruby postgresql activerecord ransack