Maison > base de données > tutoriel mysql > Introduction à la méthode de traitement des distances de longitude et de latitude à l'aide du type géométrique de MySQL

Introduction à la méthode de traitement des distances de longitude et de latitude à l'aide du type géométrique de MySQL

不言
Libérer: 2019-02-01 10:09:04
avant
2901 Les gens l'ont consulté

Le contenu de cet article est une introduction à la méthode de traitement des distances de longitude et de latitude à l'aide du type géométrique de MySQL. Il a une certaine valeur de référence. Les amis dans le besoin peuvent s'y référer.

Créer un tableau

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`)
)
Copier après la connexion

Insérer

INSERT INTO map (id, address, location) VALUES (1, 'somewhere', ST_GeomFromText('POINT(121.366961 31.190049)'));
Copier après la connexion
A noter que la fonction ST_GeomFromText doit être utilisée, et POINT() À l'intérieur se trouvent : longitude + espace + latitude

Requête

1 Afficher la latitude et la longitude

SELECT address, ST_AsText(location) AS location FROM map;
Copier après la connexion

2. Calculer la distance entre deux points

SELECT ST_Distance_Sphere(POINT(121.590347, 31.388094),location) AS distant FROM map;
Copier après la connexion
. 🎜>
Le résultat calculé, l'unité est en mètres

Notez que la longitude et la latitude dans POINT() sont désormais séparées par des virgules

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;
Copier après la connexion
Requérez les emplacements à moins de 1000 m, et trier les de loin vers près

Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!

Étiquettes associées:
source:segmentfault.com
Déclaration de ce site Web
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn
Tutoriels populaires
Plus>
Derniers téléchargements
Plus>
effets Web
Code source du site Web
Matériel du site Web
Modèle frontal