我遇到一个问题,我正在更新数据库中的数百万行,因此我不想单独更新每一行,而是希望将约 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
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)