这真的让我烦恼 - 似乎无法通过包含和堡垒来设置正确的关联。以下是有问题的模型:
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
意思是我仅根据位置而不是位置和类别来获取子类别。
我的问题出现了,当我到达子类别级别时,子类别应该依赖于类别和位置 - 它们似乎只属于其他模型中的一个,但在我的情况下它们必须属于两者。我似乎无法做到这一点。我已经尝试了很多方法来做到这一点,并且不确定我是否正确地进行了。
希望有人能指出我正确的方向。
提前致谢 基督教
答案 0 :(得分:0)
如果我正确理解你的问题,你会有类似
的内容#Category
Fruit
Apple
Banana
Vegetable
Lettuce
#Location
France
Apple
Lettuce
India
Banana
现在,你想要像
这样的东西#Hierachical output
Fruit
France
Apple
Vegetable
Lettuce
India
Fruit
Banana
在这种情况下,这不会起作用=&gt; location.subcategories.where(category_id: category.id).each
?
修改强>:
也许,这可行(除了上述变化):
<%= category.locations.all(include: sub_categories).each do |location|%>