2

这真的让我很烦 - 似乎无法通过包含等来正确设置关联。以下是有问题的模型:

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

这意味着我仅根据位置而不是位置和类别来获取子类别。

我的问题出现了,当我达到子类别级别时,子类别应该取决于类别和位置 - 它们似乎只属于其他模型中的一个,但在我的情况下它们必须属于两者。我似乎无法做到这一点。我已经尝试了很多方法来做到这一点,但我什至不确定我是否正确地去做。

希望有人能指出我正确的方向。

在此先感谢基督教

4

1 回答 1

0

如果我正确理解你的问题,你有类似的东西

#Category
Fruit
 Apple
 Banana
Vegetable
 Lettuce

#Location
France
 Apple
 Lettuce
India
 Banana

现在,你想要类似的东西

#Hierachical output
Fruit
 France
  Apple
 Vegetable
  Lettuce
India
 Fruit
  Banana

在那种情况下,这不是工作=>location.subcategories.where(category_id: category.id).each吗?

编辑

也许,这可以工作(除了上述变化):

<%= category.locations.all(include: sub_categories).each do |location|%>

于 2012-11-25T14:13:52.987 回答