ホームページ >データベース >mysql チュートリアル >MySQLのジオメトリタイプを使用して経度と緯度の距離を処理する方法の紹介

MySQLのジオメトリタイプを使用して経度と緯度の距離を処理する方法の紹介

不言
不言転載
2019-02-01 10:09:042893ブラウズ

この記事では、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() 内部は: 経度、空間、緯度

Query

1. 緯度と経度を確認します

SELECT address, ST_AsText(location) AS location FROM map;

2。 2 点間

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 サイトの他の関連記事を参照してください。

声明:
この記事はsegmentfault.comで複製されています。侵害がある場合は、admin@php.cn までご連絡ください。