除了你可能會考慮使用笛卡爾座標(x,y和z)其他答案而不是用於db存儲的緯度/經度,因爲生成的查詢表達式在數據庫服務器上的加載/時間比緯度/經度距離的可能查詢更簡單。
一個PHP實現的例子下可以找到:
http://headers-already-sent.com/geodistance/
的方法「getCartesian」將緯度/經度轉換成直角座標系和方法「getDistanceByCartesian」說明了如何計算實際距離。你需要做的是將這個距離計算從PHP轉移到SQL查詢中(這應該不那麼複雜)。
編輯,因爲我發現給一個更實際的例子
基於類,你可以在上面的鏈接我設置了2演示表爲我公司的地點和所有MC多納爾茲餐廳下找到時間在我們的周圍,並轉換緯度/經度從谷歌地圖笛卡爾X,Y,Z:
CREATE TABLE `locations` (
`id` int(11) unsigned NOT NULL AUTO_INCREMENT,
`title` varchar(255) NOT NULL DEFAULT '',
`lat` double NOT NULL,
`lng` double NOT NULL,
`x` double NOT NULL,
`y` double NOT NULL,
`z` double NOT NULL,
PRIMARY KEY (`id`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8;
INSERT INTO `locations` (`id`, `title`, `lat`, `lng`, `x`, `y`, `z`)
VALUES
(1,'Ida-Ehre-Platz 10, 20095 Hamburg',53.55053,9.99949,3727600.05477,657242.251356,5124712.81705),
(2,'Kieler Straße 191-193, 22525 Hamburg',53.57731,9.93686,3725956.4981,652753.812254,5126481.40905),
(3,'Reeperbahn 42, 20359 Hamburg',53.549951,9.964937,3728046.74189,655003.113578,5124674.56664),
(4,'Theodor-Heuss-Platz 3, 20354 Hamburg',53.56083,9.99038,3726797.15378,656489.722425,5125393.17725),
(5,'Mundsburger Damm 67, 22087 Hamburg',53.57028,10.02642,3725550.98379,658686.623655,5126017.24553),
(6,'Paul-Nevermann-Platz 1, 22765 Hamburg',53.552602,9.936678,3728135.78521,653123.397726,5124849.69505),
(7,'Friedrich-Ebert-Damm 101, 22047 Hamburg',53.58753,10.08958,3723303.02881,662522.688778,5127156.05819),
(8,'Amsinckstraße 73, 20097 Hamburg',53.54271,10.02654,3727978.07563,659123.791421,5124196.16112),
(9,'Eiffestraße 440, 20537 Hamburg',53.55214,10.04638,3726919.13256,660267.521487,5124819.17553);
CREATE TABLE `user` (
`id` int(11) unsigned NOT NULL AUTO_INCREMENT,
`name` varchar(255) NOT NULL DEFAULT '',
`lat` double NOT NULL,
`lng` double NOT NULL,
`x` double NOT NULL,
`y` double NOT NULL,
`z` double NOT NULL,
PRIMARY KEY (`id`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8;
INSERT INTO `user` (`id`, `name`, `lat`, `lng`, `x`, `y`, `z`)
VALUES
(1,'Ministry.BBS, Cremon 36, 20457 Hamburg',53.545943,9.988761,3728127.10678,656615.385203,5124409.77226),
(2,'BBS, Dorotheenstraße 60, 22301 Hamburg',53.583231,10.008315,3724617.80169,657307.963226,5126872.28974);
基於這兩個表的SQL查詢找到一定的距離(2000內的所有位置(餐館),在米在這個例子)到每個用戶(我們公司的辦公室)將是:
SELECT locations.*,
2 * 6371000.785 *
asin(
sqrt(
pow(locations.x - user.x, 2)
+ pow(locations.y - user.y, 2)
+ pow(locations.z - user.z, 2)
)/(2 * 6371000.785)
) AS distance
FROM locations, user
HAVING distance < 2000
ORDER BY distance ASC
如果你需要比「米」比你將不得不改變約爲地球半徑的東西。 6371000.785(以米爲單位)以滿足您的需要,並且還可以將所需的2000年的距離更改爲您喜歡的或存儲在用戶表格中的每個用戶的任何內容。
對於2來說,第二個缺點就是無論何時添加新的事件/客戶,您都必須維護或重新生成該列表。 – xQbert
@xQbert你說得對,我沒有說清楚。我會再補充一點。 – ean5533