问题:
您有一个包含两列 min_value 的 MySQL 表和最大值。您想要检索这两个值之间的随机值。
MySQL 中的 RAND() 函数不直接提供此功能。最接近的解决方案是 RAND() * (max-min) min,但它产生浮点数,而不是整数。要获得整数,您需要另一个像 ROUND() 这样的函数来截断小数部分,但这是不切实际的。解决方案:
最有效的方法MySQL是使用原来的表达式ROUND((RAND() * (max-min)) min)。这也是其他编程语言(例如 ActionScript、JavaScript 和 Python)中的最佳方法。PHP 和 MySQL 之间的性能比较:
如果您不确定无论是在 PHP 还是 MySQL 中生成随机值,请考虑涉及的行数。如果数据集很大,使用 MySQL 效率更高。为了演示性能差异,我们比较 100,000 次迭代的两种场景:以上是以下是一些标题选项,重点关注问题方面: 选项 1(直接且透明): * 如何在MySQL中生成一定范围内的随机整数? 选项 2(关注问题和解决方案): *的详细内容。更多信息请关注PHP中文网其他相关文章!