Ruby mysql2在单个查询中有多个语句

我有一个问题,我正在更新我的数据库中的数百万行,所以我不想单独更新每一行,而是想将〜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

相关文章

validates:conclusion,:presence=>true,:inclusion=>{...
一、redis集群搭建redis3.0以前,提供了Sentinel工具来监控各...
分享一下我老师大神的人工智能教程。零基础!通俗易懂!风趣...
上一篇博文 ruby传参之引用类型 里边定义了一个方法名 mo...
一编程与编程语言 什么是编程语言? 能够被计算机所识别的表...
Ruby类和对象Ruby是一种完美的面向对象编程语言。面向对象编...