Maison > base de données > tutoriel mysql > Comment déterminer si un point se trouve dans une zone de polygone spécifiée via MySQL

Comment déterminer si un point se trouve dans une zone de polygone spécifiée via MySQL

jacklove
Libérer: 2019-02-22 16:37:24
original
4012 Les gens l'ont consulté

Cet article présentera la méthode d'utilisation de MySQL pour déterminer si un point se trouve dans une zone de polygone spécifiée et fournira un processus complet.

Tutoriels vidéo MySQL associés recommandés : "Tutoriel MySQL"

1. Créer une table de test

CREATE TABLE `zone` ( `id` int(10) unsigned NOT NULL AUTO_INCREMENT, `polygongeo` polygon NOT NULL, PRIMARY KEY (`id`)
) ENGINE=MYISAM DEFAULT CHARSET=utf8;
Copier après la connexion

Remarque : les index spatiaux ne peuvent être créés que dans des tables dont le moteur de stockage est MYISAM

2 Insérer des données polygonales

insert into zone(polygongeo) values(POLYGONFROMTEXT('POLYGON((1 1,1 5,5 5,5 1,1 1))'));
Copier après la connexion

3. Déterminez si le point est dans la zone du polygone

Test POINT(3, 4)

select AsText(polygongeo) from zone where MBRWithin(POLYGONFROMTEXT('POINT(3 4)'),polygongeo);
Copier après la connexion

Sortie : POLYGON( (1 1,1 5,5 5,5 1,1 1))
représente le point POINT(3, 4) dans la zone du polygone
tests POINT(6, 1)

select AsText(polygongeo) from zone where MBRWithin(POLYGONFROMTEXT('POINT(6 1)'),polygongeo);
Copier après la connexion

Sortie : vide
indique le point POINT(6, 1) en dehors de la zone du polygone
Résumé : la requête spatiale mysql n'est pas très adaptée pour les coordonnées de la carte, l'interrogation des coordonnées de la carte peut donc être implémentée à l'aide de mongodb. Référence : "Méthode Mongodb pour déterminer si les coordonnées se trouvent dans une zone de polygone spécifiée"

Cet article explique comment déterminer si un point se trouve dans une zone de polygone spécifiée. une zone de polygone spécifiée via MySQL et plus de contenu connexe. Veuillez faire attention au site Web chinois php.

Recommandations associées :

Comment appeler php imagemagick pour obtenir d'anciens effets photo

Explication sur le calcul du produit cartésien de plusieurs ensembles dans PHP

Analyse de l'utilisation et des performances de open_basedir dans la configuration du répertoire d'inclusion de fichiers php

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:php.cn
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