3

我希望更好地了解活动模型/记录关系以及如何根据属性所在的位置(模型)以及我调用它们的位置来调用属性。因此,例如,我可以像这样从配方控制器中访问属性 disc_name

 def all_recipes
@recipes = Recipe.all
 end

在视图中

<% @recipes.each do |r| %>
<%= r.dish_name %>
<% end %>

现在说我想从我的控制器中访问一个名为 worldrecipes 的食谱属性,我刚刚编写了一个方法来返回同一国家/地区的所有食谱。一个国家有许多食谱作为关系

所以我的方法是

def self.top_countries
joins(:recipes).
  select('countries.*, count(*) AS recipes_count').
  group('countries.id').
  order('recipes_count DESC')
 end

我的控制器

@worldrecipes = Country.where(:name => params[:name])

并查看

<% @worldrecipes.each do |r|  %>
<%= r.name %>
<% end %>

所以访问国家名称属性很容易,因为它在国家模型中,这就是我的查询结果从(我认为)返回的地方......我的问题是我如何从我的食谱模型访问 disc_name 属性到该链接国家的名字

希望这是有道理的,有没有人有关于如何解决这个问题的指南或一些黄金法则

谢谢

4

2 回答 2

4

我认为你需要的是:

@country=Country.where(:name=>params[:name]).first
@worldrecipes=@country.recipes

在视图中:

<% @worldrecipes.each do |r|  %>
  <%= r.dish_name %>
<% end %>

这将打印该国家/地区食谱的菜名,名称由params[:name]

编辑:好的,让我为你解决这个问题:)

您的模型关系设置为每个国家/地区都有许多食谱。即一个国家有很多食谱。

所以你有了,

has_many :recipes

在 country.rb 和

belongs_to :country

在recipe.rb中

现在,当您想访问属于某个国家/地区的所有食谱时,您所做的就是调用country_record.recipes(country_record 是您需要的国家记录的对象)。

当您调用 Country.where(:name=>params[:name]) 时,您实际得到的是表示 COUNTRY 本身的活动记录对象,而不是该国家/地区的食谱,这就是打印意大利的原因。

希望这对您有所帮助。

于 2012-12-13T18:50:29.780 回答
3

对于初学者,您要确保在模型中设置了关联:

国家.rb

class Country < ActiveRecord::Base  
  has_many :recipes
end

食谱.rb

class Recipe < ActiveRecord::Base  
  belongs_to :country
end

如果您还没有这样做,请通过运行以下迁移将 foreign_key 属性添加到您的配方模型:

rails g migration add_country_id_to_recipe country_id:integer

现在您的关联已经到位,您可以轻松查询国家/地区的相应食谱。在您的控制器中:

@worldrecipes = Country.where(:name => params[:name])

那么在你看来:

<% @worldrecipes.each do |c|  %>
  <% c.recipes.each do |r| %>
   <%= r.dish_name %>
  <% end %>
<% end %>

关于“黄金法则”,我强烈建议您查看Association Basics。这是概述您可以对关联进行哪些操作的首选之地。

于 2012-12-13T18:55:59.987 回答