当快速连续执行语句时,Ruby mysql2出错

我在 Ruby中使用MysqL2客户端有一个奇怪的问题.尝试执行以下操作时:
client.query("CREATE DATABASE ...; INSERT INTO ..."); #sql truncated for brevity
client.query("SELECT 1 FROM ...") #sql truncated for brevity

Ruby抛出一个我所选择的表不存在的错误.但是,如果我尝试以下:

client.query("CREATE DATABASE ...; INSERT INTO ..."); #sql truncated for brevity
sleep 1
client.query("SELECT 1 FROM ...") #sql truncated for brevity

查询工作没有任何问题.似乎我需要给MysqL服务器一些时间来加载数据,然后才能查询.任何人都可以解释为什么会发生这种情况,以及如何以编程方式克服这种情况而不使用睡眠?

更新

我初始化客户端:

MysqL2::Client.new({
                       :adapter => "MysqL2",:host => ip_address,:username => db_username,:password => db_password,:flags => MysqL2::Client::MULTI_STATEMENTS
                   })

我检查了’query_options’属性,并且async设置为false.我已经尝试明确设置async =>虚假旗帜无济于事.

如果我使用同样的问题

Model.connection.execute(sql HERE)

注意,这些都是从Rails单元测试中执行的.

谢谢

解决方法

由于某些原因,最终工作而不需要睡眠1的唯一的事情是:
@model = Model.new    
MysqL2::Client.default_query_options[:connect_flags] |= MysqL2::Client::MULTI_STATEMENTS
@model.connection.reconnect!

相关文章

validates:conclusion,:presence=>true,:inclusion=>{...
一、redis集群搭建redis3.0以前,提供了Sentinel工具来监控各...
分享一下我老师大神的人工智能教程。零基础!通俗易懂!风趣...
上一篇博文 ruby传参之引用类型 里边定义了一个方法名 mo...
一编程与编程语言 什么是编程语言? 能够被计算机所识别的表...
Ruby类和对象Ruby是一种完美的面向对象编程语言。面向对象编...