난 레일 응용 프로그램에서 검색을 위해 ransack gem
을 사용하고 있습니다. 테이블에서 email_ids
의 배열을 검색해야합니다. 습격에서 this 문제 참조ransack gem을 통해 배열을 검색하는 방법은 무엇입니까?
, 전 단계를 수행하고이 같은 않으면 레일 콘솔에서 초기화 폴더 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
이 첨가 :
a = User.search(email_contains_array: ['[email protected]'])
그것이 만들어 SQL은 다음과 같습니다 :
"SELECT \"users\".* FROM \"users\" WHERE \"users\".\"deleted_at\" IS NULL AND (\"users\".\"email\" >> '---\n- [email protected]\n')"
이 같은 rror : 잘못된 내가 뭘한다
SELECT "users".* FROM "users" WHERE ("users"."roles" @> '{"3","4"}')
: 예상
User Load (1.8ms) SELECT "users".* FROM "users" WHERE "users"."deleted_at" IS NULL AND ("users"."email" >> '---
- [email protected]
')
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" >> '---
- [email protected]
')
이 쿼리입니까?