2

我正在使用 mysql (5.1) ruby​​ (1.8.7) 连接器从数据库中提取一些数据。有些查询的运行时间往往比预期的要长,所以我想在这些查询上设置一个连接超时。相关帖子提出的解决方案如下:

require 'rubygems'
require 'mysql'

# connect to the database
db = Mysql.real_connect( 'server', 'user', 'password', 'schema' )

# configure read timeout
db.options(Mysql::OPT_READ_TIMEOUT, 10)

# query and process
begin

  db.query("select * from ..").each_hash do |row|
    # process data if query returned 
  end

rescue Mysql::Error => err
  # handle timeout
end

但是,这似乎对我不起作用。任何想法为什么以及如何完成我所追求的?谢谢。

4

1 回答 1

3

您可能必须在实际连接之前设置选项。

db = Mysql.init
db.options(Mysql::OPT_READ_TIMEOUT, 10)
db.real_connect( 'server', 'user', 'password', 'schema' )
于 2011-09-07T07:58:41.313 回答