这真的让我很烦 - 似乎无法通过包含等来正确设置关联。以下是有问题的模型:
class Category < ActiveRecord::Base
has_many :subcategories
has_many :locations, :through => :subcategories
end
class Location < ActiveRecord::Base
has_many :subcategories
has_many :category, :through => :subcategories
end
class Subcategory < ActiveRecord::Base
belongs_to :category
belongs_to :location
end
我需要以以下结构输出:
Category.name
Location.name
Subcategory.name
Subcategory.name
Subcategory.name
(subcategory from another sub category)
控制器:
class SubcategoriesController < ApplicationController
def index
@categories = Category.all(:include => [:locations => :subcategories], :group
=>"subcategories.name")
end
看法:
<div class="categorylist">
<ul>
<%= @categories.each do |category|%>
<h3>
<%=h link_to category.name, category %>
</h3>
<%= category.locations.each do |location|%>
<h6>
<%= link_to location.name, location %>
</h6>
<%= location.subcategories.each do |subcategory|%>
<p>
<%= link_to subcategory.name, subcategory%>
</p>
<% end %>
<% end %>
<% end %>
</ul>
</div>
我想要的是:
Fruit
France
apple
granny smith
fig
India
pineapple
banana
Meat
India
cow
chicken
-------------
What I am currently getting:
Fruit
India
cow
chicken
banana
pineapple
这意味着我仅根据位置而不是位置和类别来获取子类别。
我的问题出现了,当我达到子类别级别时,子类别应该取决于类别和位置 - 它们似乎只属于其他模型中的一个,但在我的情况下它们必须属于两者。我似乎无法做到这一点。我已经尝试了很多方法来做到这一点,但我什至不确定我是否正确地去做。
希望有人能指出我正确的方向。
在此先感谢基督教