Ruby on Rails:按属性而不是id查找记录

时间:2015-01-09 10:37:58

标签: ruby-on-rails ruby-on-rails-4

我对铁轨很陌生,所以请耐心等待。

简而言之,我正在尝试创建一个表格,让婚礼的客人可以输入简单的代码(invite_code),然后再回复。 from应该使用invite_code,然后直接使用正确的invites#show视图。

到目前为止一切都那么好,但是我试图通过id之外的其他东西找到记录,我希望通过invite_code找到。假设我有一个Inviteid为4,invite_id为1234,当我输入'4'而不是'1234时,表单正在找到正确的记录”。这里有一些代码可以解释:

的routes.rb

get 'invites/search', to: 'invites#show', controller: :invites

形式

...
<%= form_tag invites_search_path, method: :get do %>
  <%= label_tag :invite_code, "#" %>
  <%= text_field_tag :invite_code, nil %>
  <%= submit_tag "Search", name: nil %>
<% end %>
...

invites_controller

...
  def show
    if params.has_key?(:invite_code)
      @invite = Invite.find(params[:invite_code])
    else
      @invite = Invite.find(params[:id])
    end
  end
...

佣金路线输出

       Prefix Verb   URI Pattern                                   Controller#Action
   info_index GET    /info/index(.:format)                         info#index
      invites GET    /invites(.:format)                            invites#index
              POST   /invites(.:format)                            invites#create
   new_invite GET    /invites/new(.:format)                        invites#new
  edit_invite GET    /invites/:id/edit(.:format)                   invites#edit
       invite GET    /invites/:id(.:format)                        invites#show
              PATCH  /invites/:id(.:format)                        invites#update
              PUT    /invites/:id(.:format)                        invites#update
              DELETE /invites/:id(.:format)                        invites#destroy

invites_search GET /invites/search(.:format)邀请#show              root GET / info #index

网址示例

.../invites/search?utf8=%E2%9C%93&invite_code=1234

"utf8"=>"✓", "invite_code"=>"1234", "id"=>"search"

应用程序似乎忽略了控制器中if语句的invite_id部分......

任何帮助表示感谢,我花了很长时间才能做到这一点......

3 个答案:

答案 0 :(得分:3)

你有几个选择。 find_by_invite_code将返回第一场比赛:

Invite.find_by_invite_code(params[:invite_code]) # First match or nil

虽然where会将所有匹配作为数组

Invite.where(invite_code: params[:invite_code]) # Array of matches. May be empty

您还可以对find_by使用以下语法:

Invite.find_by(invite_code: params[:invite_code]) # First match or nil

答案 1 :(得分:1)

find默认情况下使用id字段,而使用where代替

if params.has_key?(:invite_code)
  @invite = Invite.where(invite_code: params[:invite_code]).first

答案 2 :(得分:0)

...
  def show
    if params.has_key?(:invite_code)
      @invite = Invite.find_by(invite_code: params[:invite_code])
      # find_by argument: value
      # returns first match or nil
      # same as find, where find searches by id
      # Invite.find_by_invite_code params[:invite_code] is deprecated  
    else
      @invite = Invite.find params[:id]
    end
  end
...