2012 年 11 月 16 日更新
我想再次提出这个问题,提供一个新的赏金,以获得一个可靠的、好的解决方案。似乎只有解决方案(shubhansh
的答案)现在不能有效地工作。我会解释为什么。
首先,这是我有半径和人的实时地图,半径在red
,人在blue
。
如您所见,two
这张地图中有eight
半径的人,基本上我只得到那个人Person A
,但我没有得到Person B
,我猜 SQL 没有正确选择它,我需要它是精确的并且根据人的半径和标记半径准确。
看起来拾取的内容在半径内,而不是与半径重叠的那些,我需要它能够拾取任何相互重叠的半径的任何结果。
我正在寻找比 shubhansh 的答案更精确和准确的 SQL。您可以阅读下面的内容,以了解我究竟需要该查询来采取行动并找到准确的人。
数据,人:
+-----------+-----------+--------+
| latitude | longitude | radius |
+-----------+-----------+--------+
| 51.517395 | -0.053129 | 5.6 |
| 51.506607 | -0.116129 | 0.7 |
+-----------+-----------+--------+
请注意,radius
以公里为单位。
+-----------+-----------+-----+
| latitude | longitude | km |
+-----------+-----------+-----+
| 51.502117 | -0.103340 | 0.3 |
| 51.498913 | -0.120850 | 0.7 |
| 51.496078 | -0.108919 | 0.7 |
| 51.496506 | -0.095873 | 0.7 |
| 51.503399 | -0.090723 | 0.7 |
| 51.508049 | -0.100336 | 0.7 |
| 51.508797 | -0.112610 | 0.7 |
| 51.505535 | -0.125227 | 0.7 |
| 51.502331 | -0.108061 | 0.7 |
+-----------+-----------+-----+
我使用的当前 SQL:
SELECT ppl.latitude,
ppl.longitude,
ppl.radius
FROM
(
people ppl
),
(
SELECT latitude, longitude
FROM radiuses
) AS radius
WHERE (POW((ppl.longitude - radius.longitude) * 111.12 * COS(ppl.latitude), 2) + POW((ppl.longitude - radius.longitude) * 111.12, 2)) <= 4
GROUP BY ppl.id
可用于测试查询的 MySQL 数据,
INSERT INTO radiuses (id, latitude, longitude, km) VALUES ('1', '51.502117', '-0.103340', '0.3'), ('2', '51.498913', '-0.120850', '0.7'), ('3', '51.496078', '-0.108919', '0.7'), ('4', '51.496506', '-0.095873', '0.7'), ('5', '51.503399', '-0.090723', '0.7'), ('6', '51.508049', '-0.100336', '0.7'), ('7', '51.508797', '-0.112610', '0.7'), ('8', '51.505535', '-0.125227', '0.7'), ('9', '51.502331', '-0.108061', '0.7');
INSERT INTO people (id, latitude, longitude, radius) VALUES ('1', '51.517395', '-0.053129', '5.6'), ('2', '51.506607', '-0.116129', '0.7');
老总结
注意:所有的经纬度都是随机制作的。
我有一个地图小程序,用户可以放置他的纬度/经度位置半径,半径为 1 公里。
现在,有另一个用户可以将他的半径放在地图上的任何位置,每个半径为 1 公里(与上面的用户相同)。
像这样,用户 A是红色的,用户 B是蓝色的。
基本上,用户 A将他的半径存储在一个如下所示的表中:
+-----------+---------+-----------+-----------+
| radius_id | user_id | latitude | longitude |
+-----------+---------+-----------+-----------+
| 1 | 1 | 81.802117 | -1.110035 |
| 2 | 1 | 81.798272 | -1.144196 |
| 3 | 1 | 81.726782 | -1.135919 |
+-----------+---------+-----------+-----------+
并且用户 B将他的半径存储在另一个看起来像这样的表中 - (注意:他们每个帐户只能存储 1 个坐标):
+---------+-----------+-----------+
| user_id | latitude | longitude |
+---------+-----------+-----------+
| 6 | 81.444126 | -1.244910 |
+---------+-----------+-----------+
我希望能够在地图图片中找到那些落在定义半径内的用户,即使半径圆是接触的。只有标记C
能够拾取单个半径,何时A
和B
不。
我确信这是可能的,但我不知道如何在 MySQL 中提出这种系统。
我在 Google Developers 网站上发现它很接近,但不仅仅是我需要的性能。
编辑:我找到了一个更好的,这是非常接近的,但仍然不是我想要的,因为当我在一个表中有多个时,它使用 1 个纬度和经度坐标的界限。