如何在Rails 4中设置自定义字符串外键?

4
如何设置关联来正确地使用字符串 foreign_key 建立 has_one 关系?
class Pharmaceutic < ActiveRecord::Base
  has_one :pharmaceutic_group, foreign_key: "code"
end

class PharmaceuticGroup < ActiveRecord::Base
  belongs_to :pharmaceutic, primary_key: 'code'
end

>> Pharmaceutic.last.pharmaceutic_group                                                                                        
  Pharmaceutic Load (0.3ms)  SELECT `pharmaceutics`.* FROM `pharmaceutics` ORDER BY `pharmaceutics`.`id` DESC LIMIT 1
  PharmaceuticGroup Load (0.3ms)  SELECT `pharmaceutic_groups`.* FROM `pharmaceutic_groups` WHERE `pharmaceutic_groups`.`code` = 2 ORDER BY `pharmaceutic_groups`.`id` ASC LIMIT 1
=> nil
>> Pharmaceutic
=> Pharmaceutic(id: integer, package_type: integer, group_code: string)
>> PharmaceuticGroup
=> PharmaceuticGroup(id: integer, code: string, name: string)

例如,当药品具有group_code:aaa且PharmaceuticGroup具有code:aaa时,我希望获得Pharmaceutic.last.pharmaceutic_group.name => 'AAA group name'
1个回答

6

我想你应该使用Pharmaceutic belongs_to :pharmaceutic_groupPharmaceuticGroup has_many :pharmaceutics,像这样:

class Pharmaceutic < ActiveRecord::Base
  belongs_to :pharmaceutic_group, foreign_key: :group_code, primary_key: :code
end

class PharmaceuticGroup < ActiveRecord::Base
  has_many :pharmaceutics, foreign_key: :group_code, primary_key: :code
end

网页内容由stack overflow 提供, 点击上面的
可以查看英文原文,
原文链接