微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

php – 我可以通过MySQL查询的IN子句更新行数吗?

参见英文答案 > MySQL number of items within “in clause”                                    4个
使用IN子句在单个查询中可以更新的行数是否有限制?例如:

MysqL_query("UPDATE `table` SET `row`=1 WHERE `id` IN(1,2,3,4,5,6,7,8....5000)");

我可以一次更新所有5000行吗?或者MysqL对IN子句中的项目数有限制吗?

请注意:我想知道在单个查询中是否存在更新限制,其中MysqL会说“超出IN子句条目的最大数量”.也就是说,我正在询问MysqL中“最大数据包大小”设置以外的可能限制.

解决方法:

根据MySQL documentation for the IN function,可以在这样的列表中指定的值的数量没有硬性限制.文档具体说:

The number of values in the IN list is only limited by the max_allowed_packet value.

但是,还有另一个问题here讨论了是否存在实际限制,超出该实际限制,当与WHERE子句中的JOIN或IN(子查询)一起使用时,包含这些值的临时表可能会产生更好的性能.

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 [email protected] 举报,一经查实,本站将立刻删除。

相关推荐