我在
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单元测试中执行的.
谢谢