ruby mysql2 result_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)

有没有人遇到过这个?或者对另一种方法的任何建议?

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值