Maison  >  Article  >  base de données  >  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

不言
不言avant
2019-02-01 10:09:042846parcourir

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`)
)

Insérer

INSERT INTO map (id, address, location) VALUES (1, 'somewhere', ST_GeomFromText('POINT(121.366961 31.190049)'));
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;

2. Calculer la distance entre deux points

SELECT ST_Distance_Sphere(POINT(121.590347, 31.388094),location) AS distant FROM map;
. 🎜>
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;
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!

Déclaration:
Cet article est reproduit dans:. en cas de violation, veuillez contacter admin@php.cn Supprimer