ruby mysql2 select if_Ruby mysql2在单个查询中有多个语句

这篇博客探讨了在MySQL中如何处理查询和更新操作的并发问题。作者建议,如果你需要在流式处理查询结果的同时更新数据库,可能会遇到一致性问题。为了解决这个问题,可以创建两个独立的数据库连接:一个用于读取(查询),另一个用于更新。通过这样的方式,可以确保查询和更新操作不会相互干扰,从而维护数据一致性。
摘要由CSDN通过智能技术生成

据我了解,这是一个结果Mysql内部保护 - 您正在查询数据库,并流式传输结果,如果在此期间您还将更新结果,您不能保证任何级别的一致性。

如果您知道可以安全地在流程中进行更改,则可以通过简单地创建第二个连接来解决这个问题:

reading_client = Mysql2::Client.new(:host => 'localhost', :database => 'mehdb', :username => "root", :password => "", :flags => Mysql2::Client::MULTI_STATEMENTS)

updating_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 = reading_client.query(sql)

while results.count > 0

updates = ''

results.each do |r|

updates += "UPDATE pew SET x = 10 WHERE id = #{r['id']};"

end

updating_client.query(updates) unless updates.empty?

results = reading_client.query(sql)

end

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值