当快速连续执行语句时,Ruby mysql2出错
发布时间:2020-12-16 22:23:15 所属栏目:百科 来源:网络整理
导读:我在 Ruby中使用Mysql2客户端有一个奇怪的问题.尝试执行以下操作时: client.query("CREATE DATABASE ...; INSERT INTO ..."); #SQL truncated for brevityclient.query("SELECT 1 FROM ...") #SQL truncated for brevity Ruby抛出一个我所选择的表不存在的
我在
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! (编辑:李大同) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |