我正在尝试在 MySQL 中生成一些虚拟记录,并且需要在给定范围内创建随机纬度和经度浮点值。
例如,我需要生成介于 52.077090052913654 和 52.477040512464626 之间的纬度
和 -1.8840792500000134 和 -0.9172823750000134 之间的经度
我熟悉使用 Rand Floor 创建随机数范围,但这只会产生整数。我怎么可能做到这一点?
我正在尝试在 MySQL 中生成一些虚拟记录,并且需要在给定范围内创建随机纬度和经度浮点值。
例如,我需要生成介于 52.077090052913654 和 52.477040512464626 之间的纬度
和 -1.8840792500000134 和 -0.9172823750000134 之间的经度
我熟悉使用 Rand Floor 创建随机数范围,但这只会产生整数。我怎么可能做到这一点?
您可以使用RAND()
来获取两个值之间的随机值,如下所示:
randVal = (RAND() * (maxVal - minVal)) + minVal
用你的号码:
SELECT
(RAND() * (52.477040512464626 - 52.077090052913654)) + 52.077090052913654 AS randlatitude,
(RAND() * (-0.9172823750000134 - -1.8840792500000134)) + -1.8840792500000134 AS randlongitude