3

那些日子我正在研究 Ruby on Rails 以提高自己作为开发人员的能力,所以我开始重写我的一个 php 网站来使用该框架。
基本上该站点是一个源代码聚合器,因此我有一个语言模型和一个源模型:

class Language < ActiveRecord::Base
  has_many :sources
end

class Source < ActiveRecord::Base
  belongs_to :language
end

与源表中的 language_id 外键绑定。
该网站的主要路线之一是:

get ':language_name/:source_name.html' => 'source#show'

例如:

/ruby/discover-if-a-number-is-prime.html

在 SourceController 中,我声明了以下内容:

class SourceController < ApplicationController
  def show
    language_name, source_name = params[:language_name], params[:source_name]
    @language = Language.find_by_name(language_name) || not_found
    @source = Source.find_by( name: source_name, language_id: @language.id ) || not_found
  end
end

有没有一种聪明的方法来执行这两个查询?
也许像

@source = Source.find_by_name_and_language_name( source_name, language_name ) || not_found

如果这是一个愚蠢的问题,我很抱歉,我也在阅读使用 Rails 3.2 进行敏捷 Web 开发,但与此同时我想尝试一下。
谢谢

4

2 回答 2

5

从对 Marek 的回答的评论中询问,可以只使用 1 个查询joins

@source = Source
  .joins(:language)
  .where(languages: { name: language_name })
  .where(sources: { name: source_name })
  .first

这将返回source匹配source_name其语言匹配的第一个language_name

于 2013-08-22T14:41:15.400 回答
1

怎么样:

@source = @language.sources.find_by_name(source_name)

或者,如果您想ActiveRecord::RecordNotFound在不存在正确来源的情况下被提升(最终导致呈现 404 页面):

@source = @language.sources.find_by_name!(source_name)
于 2013-08-22T14:00:16.210 回答