1

我正在使用 Sequel 在 Sinatra 应用程序中工作。

我想进行交易,根据手册我必须使用数据库对象,我怎样才能从我的代码的任何部分获取这个对象?

4

2 回答 2

2

您可以在基本 app.rb(或等效项)中定义它,或者根据需要包含一个单独的文件,您可以在其中配置 DB 对象。

例如,在我的一个 Sinatra 应用程序中,我有一个 app.rb,其中包含一个

class App < Sinatra::Application
  #lots of stuff here...
end

require_relative 'models/init'

在我的 models/init.rb 我配置 DB

require 'sequel'

conf = YAML.load(File.open(File.expand_path('./config/dbconn.yml')))
env = ENV['RACK_ENV'] || 'development'
DB = Sequel.connect(host:conf['database'][env]['host'],
                    port:conf['database'][env]['port'],
                    database:conf['database'][env]['schema'],
                    username:conf['database'][env]['username'],
                    password:conf['database'][env]['password'],
                    adapter:conf['database'][env]['adapter'],
                    encoding:conf['database'][env]['encoding'])
raise "Unable to connect to #{conf['database'][env]['host']}" unless DB.test_connection

...

这是一种方式。希望能帮助到你。

于 2012-11-27T21:43:50.130 回答
1

您提到要从代码的任何部分引用;但是我发现封装在模型中是我倾向于包装事务的地方;从那里开始相对容易:

class X < Sequel::Model
  def self.y
    self.db.transaction {
    ...
    end
  end
  def z
    db.transaction {
    ...
    }
  end
end  
于 2014-09-28T18:04:56.923 回答