在Sequel模型中指定外键

时间:2015-01-22 14:14:44

标签: mysql ruby sequel sequel-gem

我有两种模式:

富:

class Foo < Sequel::Model (:FOO_TABLE)

  set_primary_key [:KEY]

  # has many Bars
  one_to_many :bars

end

栏:

class Bar < Sequel::Model (:BAR_TABLE)

  # compound key
  set_primary_key [:KEY,:NBR]

  # belongs to Foo
  many_to_one :foo

end

加载Foo按预期工作:

irb> foo = Foo['ABC']
=> #<Foo @values={:KEY=>"ABC", :NAME=>"ABC name"}>

但是,当我尝试加载Bars时,出现错误:

irb> bars = foo.bars
=> Sequel::DatabaseError: Mysql2::Error: Unknown column 'BAR_TABLE.foo_id' in 'where clause'

在我的续集模型中指定foreign_key的正确方法是什么?

**编辑**

使用MySQL2。

1 个答案:

答案 0 :(得分:1)

一般来说,你想看看the options for associations。具体来说,你需要告诉Sequel如何在给定foo的情况下找到正确的“条形图”。

如果您只是在BAR_TABLE中使用非标准名称作为外键引用,则可以执行以下操作:

class Foo < Sequel::Model(:BAR_TABLE)
  one_to_many :bars, :key => :my_foo_id
end

class Bar < Sequel::Model(:BAR_TABLE)
  many_to_one :foo, :key => :my_foo_id
end

实施例/证明:

require 'sequel'
DB = Sequel.sqlite
DB.create_table(:FOOBOY){ Integer :myd; String :name; primary_key [:myd] }
DB.create_table(:BARSTON){ Integer :myd; String :name; foreign_key :my_foo_id, :FOOBOY; primary_key [:myd] }

DB[:FOOBOY] << { myd:1, name:'Furst' }
DB[:FOOBOY] << { myd:2, name:'Surkind' }

DB[:BARSTON] << { myd:1, name:'Bobby', my_foo_id:1 }
DB[:BARSTON] << { myd:2, name:'Jimmy', my_foo_id:1 }
DB[:BARSTON] << { myd:3, name:'XYZZY', my_foo_id:2 }

class Foo < Sequel::Model(:FOOBOY)
  one_to_many :bars, :key => :my_foo_id
end

class Bar < Sequel::Model(:BARSTON)
  many_to_one :foo, :key => :my_foo_id
end

Foo[1]
#=> #<Foo @values={:myd=>1, :name=>"Furst"}>

Foo[1].bars
#=> [#<Bar @values={:myd=>1, :name=>"Bobby", :my_foo_id=>1}>, #<Bar @values={:myd=>2, :name=>"Jimmy", :my_foo_id=>1}>]

Foo[1].bars.last.foo
#=> #<Foo @values={:myd=>1, :name=>"Furst"}>

Bar.last
#=> #<Bar @values={:myd=>3, :name=>"XYZZY", :my_foo_id=>2}>

Bar.last.foo
#=> #<Foo @values={:myd=>2, :name=>"Surkind"}>