ransack_alias在查询

时间:2017-10-11 16:03:37

标签: ruby-on-rails ransack

我在我的搜索表单中使用Ransack,并且我尝试使用ransack_alias来缩短查询。但是,当我执行搜索时,别名字段根本不会过滤查询。我简化了我的表单,只有一个简单的别名,但它似乎不起作用。

用户模型

class User < ActiveRecord::Base
  ransack_alias :ec, :email_cont
end

index.html.haml

= search_form_for @q, url: users_path, html: {method: :get} do |f|
  = f.label :ec
  = f.search_field :ec
  = f.submit 'Search'

如果我在控制器内放置一个断点:

>> User.count
10

>> User.ransack({email_cont: "test@email.com"}).result.count
(93.8ms)  SELECT COUNT(*) FROM "users" WHERE ("users"."email" ILIKE '%test@email\.com%')
1

>> params[:q]
{"ec" => "test@email.com"}

>> User.ransack(params[:q]).result.count
(28.4ms)  SELECT COUNT(*) FROM "users"
10

>> User._ransack_aliases
{"ec" => "email_cont"}

我在这里做错了什么?

1 个答案:

答案 0 :(得分:3)

ransack_alias用于别名属性,但不用于比较键。

class User < ActiveRecord::Base
  ransack_alias :e, :email
end

> User.ransack({'e_cont' => "user"}).result.count 
(0.2ms)  SELECT COUNT(*) FROM "users" WHERE ("users"."email" LIKE '%user%')