10

我正在阅读关于自我引用 has_many :through 数据情况的文章,因为我正在尝试构建一个使用它们的 Rails 应用程序。我在网上找到了这个示例情况,对此我有一个疑问。让我从这个人的博客中发布这个示例代码:

create_table :animals do |t|
  t.string :species
end
create_table :hunts do |t|
  t.integer :predator_id
  t.integer :prey_id
  t.integer :capture_percent
end

class Animal < ActiveRecord::Base
  has_many :pursuits,  :foreign_key => 'predator_id',
                       :class_name => 'Hunt',
                       :dependent => :destroy
  has_many :preys,     :through => :pursuits
  has_many :escapes,   :foreign_key => 'prey_id',
                       :class_name => 'Hunt',
                       :dependent => :destroy
  has_many :predators, :through => :escapes
end
class Hunt < ActiveRecord::Base
  belongs_to :predator, :class_name => "Animal"
  belongs_to :prey,     :class_name => "Animal"
end

假设我正在构建一个网页,其中列出了其数据库中的第一个动物。此标题下方是百分比列表 (capture_percent)。每个百分比都是指该页面的动物狩猎的动物,但它不会告诉您动物的名称,只是百分比。点击任何给定的百分比将带您到相应的动物页面。

我知道,这是一个很难解决的问题,但我正在努力解决这个问题。我是否必须为 CapturePercent 创建一个单独的表?

4

1 回答 1

9

我是否必须为 CapturePercent 创建一个单独的表?

一点也不,这似乎没有什么复杂的:

<ul>
<% @animal.pursuits.each do |pursuit| %>
  <li><%= link_to "#{pursuit.capture_percent}%", pursuit.prey %></li>
<% end %>
</ul>
于 2008-12-13T10:06:23.650 回答