この記事では、MySQL のジオメトリ タイプを使用して経度と緯度の距離を処理する方法を紹介します。必要な方は参考にしていただければ幸いです。
テーブルの作成
CREATE TABLE `map` ( `id` int(11) NOT NULL, `address` varchar(255) NOT NULL DEFAULT '', `location` geometry NOT NULL, PRIMARY KEY (`id`), SPATIAL KEY `idx_location` (`location`) )
挿入
INSERT INTO map (id, address, location) VALUES (1, 'somewhere', ST_GeomFromText('POINT(121.366961 31.190049)'));
ST_GeomFromText
関数を使用する必要があることに注意してください。 andPOINT()
内部は: 経度、空間、緯度
SELECT address, ST_AsText(location) AS location FROM map;
SELECT ST_Distance_Sphere(POINT(121.590347, 31.388094),location) AS distant FROM map;
計算結果、単位はメートルです。
POINT() の経度と緯度は、1000 メートル未満の距離にあるクエリ位置をカンマで区切っていることに注意してください。 、遠くから近い順に並べ替えます
SELECT id, address, ST_Distance_Sphere(POINT(121.590347, 31.388094),location) AS distant FROM map WHERE ST_Distance_Sphere(POINT(121.590347, 31.388094),location) < 1000 ORDER BY distant;
以上がMySQLのジオメトリタイプを使用して経度と緯度の距離を処理する方法の紹介の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。