php – 大数据集:mysql_unbuffered_query with innodb?
内容导读
互联网集市收集整理的这篇技术教程文章主要介绍了php – 大数据集:mysql_unbuffered_query with innodb?,小编现在分享给大家,供广大互联网技能从业者学习和参考。文章包含875字,纯文字阅读大概需要2分钟。
内容图文
基本上我需要对大数据集进行操作,所以我开始认为我可以使用mysql_unbuffered_query来不将所有结果加载到RAM中.
但我读到,当我获取行时,我无法在同一个表上运行任何其他查询.如果桌子是innodb,我想知道这仍然是真的吗?
Innodb在执行mysql_unbuffered_query时是否使用行级锁定?
伪代码是:
$q = mysql_unbuffered_query("SELECT * FROM largeTable");
while($r = fetch($q)) {
if (some condition)
mysql_query("UPDATE largeTable SET field = somevalue WHERE id = someid");
}
解决方法:
您无法运行另一个查询的原因是查询的结果未被预取,并且您正在处理游标.您仍然可以打开另一个连接来处理其他查询.
请记住,MySQL中有几个设置,影响执行查询后连接保持打开的时间,如果数据集很大,服务器可以在处理查询之前关闭连接(请参阅wait_timeout和net_write_timeout) )
好的替代方法是在循环中执行查询,限制行数,并使用WHERE pk>值ORDER BY pk ASC,其中pk是主键,并且值是从上一个查询中检索到的最后一个值(就好像只实现了限制,偏移性能会在大偏移时降低)
内容总结
以上是互联网集市为您收集整理的php – 大数据集:mysql_unbuffered_query with innodb?全部内容,希望文章能够帮你解决php – 大数据集:mysql_unbuffered_query with innodb?所遇到的程序开发问题。 如果觉得互联网集市技术教程内容还不错,欢迎将互联网集市网站推荐给程序员好友。
内容备注
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 gblab@vip.qq.com 举报,一经查实,本站将立刻删除。
内容手机端
扫描二维码推送至手机访问。