我有一个问题,我正在更新我的数据库中的数百万行,所以我不想单独更新每一行,而是想将〜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)
有没有人遇到过这个?或者对另一种方法的任何建议?
解决方法
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。