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

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

不言
リリース: 2019-02-01 10:09:04
転載
2915 人が閲覧しました

この記事では、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 までご連絡ください。
最新の問題
人気のチュートリアル
詳細>
最新のダウンロード
詳細>
ウェブエフェクト
公式サイト
サイト素材
フロントエンドテンプレート