Ruby mysql2在单个查询中有多个语句
发布时间:2020-12-17 03:54:08 所属栏目:百科 来源:网络整理
导读:我有一个问题,我正在更新我的数据库中的数百万行,所以我不想单独更新每一行,而是想将?1000个语句组合并到一个查询中. 我已经启用了MULTI_STATEMENTS client = Mysql2::Client.new(:host = 'localhost',:database = 'mehdb',:username = "root",:password = "
我有一个问题,我正在更新我的数据库中的数百万行,所以我不想单独更新每一行,而是想将?1000个语句组合并到一个查询中.
我已经启用了MULTI_STATEMENTS client = Mysql2::Client.new(:host => 'localhost',:database => 'mehdb',:username => "root",:password => "",:flags => Mysql2::Client::MULTI_STATEMENTS) 这是我正在运行的代码的示例 sql = "SELECT id,x FROM pew WHERE x IS NULL LIMIT 1000" results = db_read.query(sql) while results.count > 0 updates = '' results.each do |r| updates += "UPDATE pew SET x = 10 WHERE id = #{r['id']};" end db_write.query(updates) unless updates.empty? results = db_read.query(sql) end 这项工作在第一次运行期间没问题,但是当它触发第二组更新时,我收到此错误消息 `query': Commands out of sync; you can't run this command now (Mysql2::Error) 有没有人遇到过这个?或者对另一种方法的任何建议? 解决方法
这个问题的简短回答是当启用MULTI_STATEMENTS时,mysql希望你处理查询的结果.
快速解决方法是在每组多个更新语句之后执行与此类似的操作 while db_write.next_result db_write.store_result rescue '' end (编辑:李大同) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |