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

标签 ruby-on-rails ruby foreign-keys associations ruby-on-rails-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)

例如当:Pharmaceutic 有 group_code:aaa 并且 PharmaceuticGroup 有代码:aaa 我想得到 Pharmaceutic.last.pharmaceutic_group.name => ' AAA组名'

最佳答案

我猜你应该使用 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

关于ruby-on-rails - 如何在 Rails 4 中设置自定义字符串外键?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/17787586/

相关文章:

python - MySQL - 无法定义外键

sql - 添加新字段与创建单独的表

ruby-on-rails - 如何从 rake 任务中调用 Rails 缓存清扫器?

ruby-on-rails - Ruby (/rails?) 顶级命名空间

ruby-on-rails - has_many through rails 的所有记录

ruby-on-rails - 此括号语法的 Ruby 2.4 文档

ruby-on-rails - 为什么使用资源时 Rails routes.rb 中的顺序很重要?

ruby-on-rails - Capistrano 无法部署到远程服务器

javascript - 正则表达式 - 以特定字符串开头但不以另一个子字符串结尾

MySQL - 从多个表中删除外键