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

SQLite Discussion :

sqrt pour geocodage


Sujet :

SQLite

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Candidat au Club
    Profil pro
    Inscrit en
    Janvier 2011
    Messages
    3
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Janvier 2011
    Messages : 3
    Par défaut sqrt pour geocodage
    Bonjour,
    je me sers d'une BDD SQLITE gérant des données géographiques avec latitude et longitude.
    Je lance une requête me remontant les points par rapport à ma position GPS.
    Par contre je n'arrive pas à trier les résultats par ordre de proximité de ma position.
    Je voudrais faire
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    select latitude, longitude, sqrt((latitude * latitude )+(longitude * longitude )) distance 
    from matable 
    order by distance;
    mais pas de fonction SQRT sous sqlite
    ni non plus d'exposant du type :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    select latitude, longitude, ((latitude * latitude )+(longitude * longitude )) ** 0.5 distance 
    from matable 
    order by distance;
    Une idée pour réaliser cette requête ?
    Merci d'avance

    Vince

  2. #2
    Candidat au Club
    Profil pro
    Inscrit en
    Janvier 2011
    Messages
    3
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Janvier 2011
    Messages : 3
    Par défaut Correctif
    En fait il faut lire :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    select latitude, longitude, sqrt(((malatitude-latitude) * (malatitude-latitude ))+((malongitude-longitude) *( malongitude-longitude ))) distance 
    from matable 
    order by distance;
    Avec malatitude et malongitude étant mes données de localisation GPS

    Ceci pour une application à réaliser sous ANDROID

    Merci de vos retours.

  3. #3
    Candidat au Club
    Profil pro
    Inscrit en
    Janvier 2011
    Messages
    3
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Janvier 2011
    Messages : 3
    Par défaut [RESOLU] Réponse trouvé
    Bonjour,
    En fait je suis pas très futé car ce n'est pas la distance qui m'intéresse mais juste l'ordre de tri des résultats par distance croissante en regard de ma position.
    Donc le simple calcul sans la racine carré me suffit amplement !!

    Voila ce que j'ai testé sous sqllitebrowser :
    valorisation de données fictives
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    insert into matable ( latitude, longitude ) values ( 1, 2 );
    insert into matable ( latitude, longitude ) values ( 1, 3 );
    insert into matable ( latitude, longitude ) values ( 1, 4 );
    insert into matable ( latitude, longitude ) values ( 2, 1 );
    insert into matable ( latitude, longitude ) values ( 2, 2 );
    insert into matable ( latitude, longitude ) values ( 2, 3 );
    insert into matable ( latitude, longitude ) values ( 2, 4 );
    insert into matable ( latitude, longitude ) values ( 3, 1 );
    insert into matable ( latitude, longitude ) values ( 3, 2 );
    insert into matable ( latitude, longitude ) values ( 3, 3 );
    Test de la remontée d'onformations :
    hypothese je suis en 3, 2
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    select latitude, longitude from matable;
     
    select latitude, longitude ,((latitude -3) * (latitude - 3)) + ((longitude -2) * (longitude -2) ) distance 
    from matable 
    order by distance;
    resultat :
    3 2 0
    2 2 1
    3 1 1
    3 3 1
    2 1 2
    2 3 2
    1 2 4
    1 3 5
    2 4 5
    1 4 8

    hypothese je suis en 0, 0
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    select latitude, longitude ,((latitude -0) * (latitude - 0)) + ((longitude -0) * (longitude -0) ) distance from matable order by distance;
    resultat :
    1 2 5
    2 1 5
    2 2 8
    1 3 10
    3 1 10
    2 3 13
    3 2 13
    1 4 17
    3 3 18
    2 4 20

    Si cela peut en aider certains !

    En fait le fait de formuler ma demande m'a donné la solution !

    Merci à tous

    Vince

  4. #4
    Invité de passage
    Inscrit en
    Juin 2011
    Messages
    1
    Détails du profil
    Informations forums :
    Inscription : Juin 2011
    Messages : 1
    Par défaut
    Citation Envoyé par vince_38 Voir le message
    Si cela peut en aider certains !
    En fait le fait de formuler ma demande m'a donné la solution !

    Merci à tous
    Je me suis inscris sur le forum juste pour te dire que tu es un génie
    Tu m’enlèves un belle épine du pied !!


    Merci à toi.

+ Répondre à la discussion
Cette discussion est résolue.

Discussions similaires

  1. résultats pour 0.5*erfc(x/sqrt(2))
    Par philben dans le forum MATLAB
    Réponses: 9
    Dernier message: 26/07/2012, 18h06
  2. Outils, cours et NOUVEAUX tutoriels pour Borland C++Builder
    Par hiko-seijuro dans le forum C++Builder
    Réponses: 10
    Dernier message: 12/03/2006, 22h33
  3. [TP7] Calculer sin, cos, tan, sqrt via le FPU
    Par zdra dans le forum Assembleur
    Réponses: 8
    Dernier message: 25/11/2002, 04h09
  4. Tutoriels et liens pour le Borland Database Engine
    Par Community Management dans le forum Paradox
    Réponses: 0
    Dernier message: 25/03/2002, 10h23
  5. Réponses: 2
    Dernier message: 20/03/2002, 23h01

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