4

我正在为其中一所学校建立一个收费模块。为了使费用模块正常工作,我想定义费用模板(结构),其中包含不同类型的费用(入场费、图书馆费、体育费等)、各种折扣和任何适用的税费。费用、折扣和税收被定义为不同的模型,因为它们包含不同的属性。

以下是各种型号...

首先是费用模板

class FeeTemplate < ActiveRecord::Base
    has_many :fee_template_particulars
end

然后是费用详情..

class FeeParticular < ActiveRecord::Base
    belongs_to :fee_template
    belongs_to :particulars, :polymorphic => true
end

现在收费、折扣和税收模式

class Fee < ActiveRecord::Base
    has_many :fee_particulars, :as => particulars
end

class Discount < ActiveRecord::Base
    has_many :fee_particulars, :as => particulars
end

class Tax < ActiveRecord::Base
    has_many :fee_particulars, :as => particulars
end

本质上,FeeTemplateParticular 的数据库表将有一个类型列来存储费用/折扣/税的类型和 id 记录。

想问你们几个关于我必须实施的场景的问题..

  1. 这种方法(多态)是否适合这种情况?

  2. 如果上面没问题并且知道多态关联以一种方式工作,但在我的情况下,我将不得不从费用详情中找到每种类型费用/折扣/税的详细信息,而不是相反。那怎么做?

  3. 有没有更好的方法来解决这个问题。

提前致谢。

4

1 回答 1

1

是的,这很好。

您有 has_many 的 field_particular 来查找不同类型的详细信息。您将能够针对细节的不同行为进行不同的分类。我认为这是针对您的问题的一个非常好的设计。

于 2012-04-17T21:15:50.110 回答