IdentifiantMot de passe
Loading...
Mot de passe oublié ?Je m'inscris ! (gratuit)
Navigation

Inscrivez-vous gratuitement
pour pouvoir participer, suivre les réponses en temps réel, voter pour les messages, poser vos propres questions et recevoir la newsletter

Requêtes MySQL Discussion :

Optimisation aggregation (count) de points géographiques par zone


Sujet :

Requêtes MySQL

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre confirmé Avatar de cyrille37
    Profil pro
    Développeur informatique
    Inscrit en
    Juin 2005
    Messages
    155
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations professionnelles :
    Activité : Développeur informatique

    Informations forums :
    Inscription : Juin 2005
    Messages : 155
    Par défaut Optimisation aggregation (count) de points géographiques par zone
    Bonjour,

    J'ai la table "notes" avec les champs "latitude" et "longitude" (ce sont les "Notes" d'OpenStreetMap). Pour faire un heatmap (carte de chaleur) je souhaite avoir le compte des points (des "Notes") en "découpant la planète" en rectangles.

    La requête actuelle fonctionne bien:

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    set @dlon=10;
    set @dlat=10;
    select count(*) as count, lon, lat
    from ( select
        round(longitude/@dlon)*@dlon as lon,
        round(latitude/@dlat)*@dlat as lat
        from notes N) N1
    group by lon, lat
    Comme il y a 3 000 000 de lignes et dans quelques mois encore plus ;-)

    Voyez vous une autre façon de faire pour gagner en vitesse ?
    Est-ce que les fonctions "spatial" pourraient apporter plus de performance ?

    Merci à vous :-)

  2. #2
    Expert confirmé
    Avatar de Séb.
    Profil pro
    Inscrit en
    Mars 2005
    Messages
    5 348
    Détails du profil
    Informations personnelles :
    Âge : 47
    Localisation : France

    Informations professionnelles :
    Secteur : High Tech - Opérateur de télécommunications

    Informations forums :
    Inscription : Mars 2005
    Messages : 5 348
    Billets dans le blog
    17
    Par défaut
    Le problème est le calcul répété inutilement à chaque requête sur des millions de lignes.
    Si la précision de l'arrondi des coordonnées te suffit à déterminer des rectangles, alors je pense que les fonctions spatiales ne sont pas utiles.
    Perso je stockerai le calcul de l'arrondi en plus des coordonnées réelles.

Discussions similaires

  1. [MySQL] Comment optimiser les COUNT ?
    Par DavidDeTroyes dans le forum PHP & Base de données
    Réponses: 6
    Dernier message: 17/04/2007, 18h54
  2. Réponses: 6
    Dernier message: 23/01/2007, 17h20
  3. Réponses: 2
    Dernier message: 03/12/2006, 17h56
  4. Remplacer doublons lignes par zone de liste
    Par toto10 dans le forum Access
    Réponses: 5
    Dernier message: 13/07/2006, 12h19
  5. Réponses: 11
    Dernier message: 24/07/2003, 09h24

Partager

Partager
  • Envoyer la discussion sur Viadeo
  • Envoyer la discussion sur Twitter
  • Envoyer la discussion sur Google
  • Envoyer la discussion sur Facebook
  • Envoyer la discussion sur Digg
  • Envoyer la discussion sur Delicious
  • Envoyer la discussion sur MySpace
  • Envoyer la discussion sur Yahoo