我正在使用 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
但是,这似乎对我不起作用。任何想法为什么以及如何完成我所追求的?谢谢。