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 :

probleme de sous requête


Sujet :

Requêtes MySQL

  1. #1
    Membre habitué
    Profil pro
    Inscrit en
    Juin 2006
    Messages
    412
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Juin 2006
    Messages : 412
    Points : 145
    Points
    145
    Par défaut probleme de sous requête
    Bonjour,

    je cherche une solution en lien avec la requête suivante qui m'affiche les villes les plus proches d'une ville sélectionné dans un formulaire.

    ma table table_villes

    id-ville,nom_ville,cp_ville, lati, longi

    et ma table table_rubrique

    id_rubrique, nom_rubrique, ville_rubrique,id-ville

    la requête fonctionne , utilise une procédure stockée et affiche bien les villes dans un rayon de 7 km

    ( je récupère les valeur de latitude et longitude via l'url , variable $lat et $long )

    la requête :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    SELECT id_ville,nom_ville,cp_ville ,longi,lati,  get_distance_metres(
    '".$lat."', '".$long."', lati, long
    ) AS distance FROM table_villes WHERE get_distance_metres(
    '".$lat."', '".$long."',  longi,lati
    )  BETWEEN 500 AND 7000 
     ORDER BY rand  ()
    ça fonctionne bien , mais j'aimerais en plus pouvoir afficher le caractère * à coté de chaque ville distante qui sont aussi dans la table table_rubrique

    j'ai essayé cette sous requête


    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    SELECT ville_rubrique FROM table_rubrique WHERE ville_rubrique IN (  SELECT id_ville,nom_ville,cp_ville ,longi,lati,  get_distance_metres(
    '".$lat."', '".$long."', lati, long
    ) AS distance FROM table_villes WHERE get_distance_metres(
    '".$lat."', '".$long."',  longi,lati
    )  BETWEEN 500 AND 7000 
     ORDER BY rand  () )
    mais ça ne marche pas j'ai l'erreur suivante

    Operand should contain 1 column(s)

    merci de votre aide

  2. #2
    Membre expert
    Avatar de ericd69
    Homme Profil pro
    Développeur informatique
    Inscrit en
    Avril 2011
    Messages
    1 919
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Isère (Rhône Alpes)

    Informations professionnelles :
    Activité : Développeur informatique
    Secteur : High Tech - Multimédia et Internet

    Informations forums :
    Inscription : Avril 2011
    Messages : 1 919
    Points : 3 295
    Points
    3 295
    Billets dans le blog
    1
    Par défaut
    c'est normal

    tu veux affecter à ville-rubrique les valeurs:
    id_ville,nom_ville,cp_ville ,longi,lati, get_distance_metres('".$lat."', '".$long."',lati, long) AS distance FROM table_villes

    ici c'est juste id_ville qui t'intéresse, ta requête est donc:
    Code sql : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
     
    SELECT ville_rubrique
    FROM table_rubrique
    WHERE ville_rubrique IN
       (SELECT id_ville
        FROM table_villes 
        WHERE get_distance_metres( '".$lat."', '".$long."',  longi,lati)
           BETWEEN 500 AND 7000 
        ORDER BY rand  ())

    ton order by n'est qu'une perte de temps d'exécution et de ressource car vu que tu limites pas ta recherche et que tu DOIS avoir toutes les villes à une certaine distance... vire le, ça n'ira que plus vite

    soyons pensez à mettre quand votre problème est résolu ou à utiliser pour les réponses pertinentes...
    ne posez pas de problématique soi-disant simplifiée sur des problèmes que vous n'êtes pas capable de résoudre par respect pour ceux qui planchent dessus... sinon: et à utiliser pour insérer votre code...

  3. #3
    Membre habitué
    Profil pro
    Inscrit en
    Juin 2006
    Messages
    412
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Juin 2006
    Messages : 412
    Points : 145
    Points
    145
    Par défaut
    Merci pour cette réponse

    je suis obligé de reprendre ceci

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    get_distance_metres('".$lat."', '".$long."', lati, long) AS distance FROM
    sinon comment afficher les villes distantes ?

    lorsque je met ton code , pas d'erreur mais ça ne m'affiche aucune des villes proches de celles passées en paramètre , puisque je ne récupère pas les données des champs pour les longitudes et latitudes ainsi que la procédure stockée get_distance_metres ) sans ces paramètres je ne peux afficher les villes proche de la ville ciblée

    peut être une piste ici

    http://dev.mysql.com/doc/refman/5.0/...ubqueries.html

    merci de votre aide

  4. #4
    Membre expert
    Avatar de ericd69
    Homme Profil pro
    Développeur informatique
    Inscrit en
    Avril 2011
    Messages
    1 919
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Isère (Rhône Alpes)

    Informations professionnelles :
    Activité : Développeur informatique
    Secteur : High Tech - Multimédia et Internet

    Informations forums :
    Inscription : Avril 2011
    Messages : 1 919
    Points : 3 295
    Points
    3 295
    Billets dans le blog
    1
    Par défaut
    j'ai juste corrigé ta requête pour qu'elle marche

    j'ai pas dit qu'elle ferait ce que tu voulais, le but c'est que tu comprenne à quoi sert l'opérateur in

    mets les create de tes 2 table ou un describe d'elles

    j'ai l'impression que certaine données de la seconde sont en trop

    et je verrais mieux quelle données il faut prendre pour que tu ais ce que tu veux
    soyons pensez à mettre quand votre problème est résolu ou à utiliser pour les réponses pertinentes...
    ne posez pas de problématique soi-disant simplifiée sur des problèmes que vous n'êtes pas capable de résoudre par respect pour ceux qui planchent dessus... sinon: et à utiliser pour insérer votre code...

  5. #5
    Membre habitué
    Profil pro
    Inscrit en
    Juin 2006
    Messages
    412
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Juin 2006
    Messages : 412
    Points : 145
    Points
    145
    Par défaut
    j'ai une table table_ville avec les champs suivants

    id-ville, nom_ville, cp_ville, lati, longi

    et une table table_rubrique

    id_rubrique, nom_rubrique, ville_rubrique,id-ville

    les champs id_ville des deux tables sont identiques

    dans ma requête initiale j'ai une procédure stockée qui sert à calculer la distance de villes à partir d'une longitude et d'une latitude (get_distance_metres ) et je récupère des variables d'url pour les longitudes et latitudes ( $lat et $long )

    cette requête fonctionne bien jusqu’à présent, ce que je voulais c'est ajouter la possibilité d'afficher à coté de chaque ville distante sélectionnée par la requête , un caractère quelconque ( par exemple * , ou une image ) chaque fois qu'il y'a correspondance de villes ( via l'id_ville ) dans d'un coté le résultat de la requête sur table_ville et de l'autre les villes de table_rubrique

  6. #6
    Membre expert
    Avatar de ericd69
    Homme Profil pro
    Développeur informatique
    Inscrit en
    Avril 2011
    Messages
    1 919
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Isère (Rhône Alpes)

    Informations professionnelles :
    Activité : Développeur informatique
    Secteur : High Tech - Multimédia et Internet

    Informations forums :
    Inscription : Avril 2011
    Messages : 1 919
    Points : 3 295
    Points
    3 295
    Billets dans le blog
    1
    Par défaut
    je comprends pas ton ville_rubrique,id-ville dans ta dernière table?

    ps: c'est une fonction stockée pas une procédure stockée qui fait ton calcul
    soyons pensez à mettre quand votre problème est résolu ou à utiliser pour les réponses pertinentes...
    ne posez pas de problématique soi-disant simplifiée sur des problèmes que vous n'êtes pas capable de résoudre par respect pour ceux qui planchent dessus... sinon: et à utiliser pour insérer votre code...

  7. #7
    Membre habitué
    Profil pro
    Inscrit en
    Juin 2006
    Messages
    412
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Juin 2006
    Messages : 412
    Points : 145
    Points
    145
    Par défaut
    oui c'est vrai la colonne "ville_rubrique" est de trop

    ma table table_rubrique est comme ça maintenant

    id_rubrique, nom_rubrique, id_ville

    oui désolé pour le mauvais terme c'est effectivement une fonction mysql qui fait le boulot , mais stockée dans une procédure.

  8. #8
    Membre expert
    Avatar de ericd69
    Homme Profil pro
    Développeur informatique
    Inscrit en
    Avril 2011
    Messages
    1 919
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Isère (Rhône Alpes)

    Informations professionnelles :
    Activité : Développeur informatique
    Secteur : High Tech - Multimédia et Internet

    Informations forums :
    Inscription : Avril 2011
    Messages : 1 919
    Points : 3 295
    Points
    3 295
    Billets dans le blog
    1
    Par défaut
    mieux lol

    bon donc en fait la table 2 te donne l'id de ta ville en fonction de ta rubrique

    un bon formulaire donnerait donc cette id et pas la longitude et la latitude

    donc supposons que tu as 2 informations:
    l'id de la ville cible: $idv
    l'id de la rubrique: $idr

    on veut les villes qui vont répondre à ces 2 conditions:
    à la distance voulue de $idv et où $idr est présent

    une façon de le faire pour éviter les aller retour entre mysql et php est une petite procédure stockée...

    c'est quoi le type des paramètres de ta fonction get_distance_metres?
    soyons pensez à mettre quand votre problème est résolu ou à utiliser pour les réponses pertinentes...
    ne posez pas de problématique soi-disant simplifiée sur des problèmes que vous n'êtes pas capable de résoudre par respect pour ceux qui planchent dessus... sinon: et à utiliser pour insérer votre code...

  9. #9
    Membre habitué
    Profil pro
    Inscrit en
    Juin 2006
    Messages
    412
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Juin 2006
    Messages : 412
    Points : 145
    Points
    145
    Par défaut
    en fait voila comment ça se passe , j'ai un petit formulaire qui me donne en résultat le lien d'une ville ( requête sur table_ville ) sur ce lien j’envoie via l'url des paramètres comme le nom de la ville, son id, et les longitudes et latitudes ainsi que le code postal

    sur la page cible je récupère ces paramètres et j'affiche les villes qui sont situées à moins de 7 bornes de cette ville. Pour ce faire j'utilise la procédure stockée suivante

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    21
    22
    23
    24
    DELIMITER |
    DROP FUNCTION IF EXISTS get_distance_metres|
    CREATE FUNCTION get_distance_metres (latitudeDepart DOUBLE, longitudeDepart DOUBLE, latitudeArrivee DOUBLE, longitudeArrivee DOUBLE) RETURNS DOUBLE
    BEGIN
        DECLARE radLongitudeDepart DOUBLE;
        DECLARE radLatitudeDepart DOUBLE;
        DECLARE radLongitudeArrivee DOUBLE;
        DECLARE radLatitudeArrivee DOUBLE;
     
        DECLARE dlo DOUBLE;
        DECLARE dla DOUBLE;
        DECLARE a DOUBLE;
     
        SET radLongitudeDepart = RADIANS(longitudeDepart);
        SET radLatitudeDepart = RADIANS(latitudeDepart);
        SET radLongitudeArrivee = RADIANS(longitudeArrivee);
        SET radLatitudeArrivee = RADIANS(latitudeArrivee);
     
        SET dlo = (radLongitudeArrivee - radLongitudeDepart) / 2;
        SET dla = (radLatitudeArrivee - radLatitudeDepart) / 2;
     
        SET a = SIN(dla) * SIN(dla) + COS(radLatitudeDepart) * COS(radLatitudeArrivee) * SIN(dlo) * SIN(dlo);
        RETURN (6378137 * 2 * ATAN2(SQRT(a), SQRT(1 - a)));    
    END|
    et la requête qui fonctionne bien , que je remet ici

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    SELECT id_ville,nom_ville,cp_ville ,longi,lati,  get_distance_metres(
    '".$lat."', '".$long."', lati, long
    ) AS distance FROM table_villes WHERE get_distance_metres(
    '".$lat."', '".$long."',  longi,lati
    )  BETWEEN 500 AND 7000 
     ORDER BY rand  ()
    ça m’affiche bien une liste de villes situés dans les environs et leur code postal

    maintenant ce que j'aimerais faire en plus d'afficher ça c'est à partir d'une autre table ( table_rubrique ) afficher à coté de chacune de ces villes un caractère symbolisant le type de rubrique ( colonne nom_rubrique )

    la table_rubrique

    id_rubrique, nom_rubrique, ville_rubrique,id-ville

    la table_ville

    id-ville, nom_ville, cp_ville, lati, longi

  10. #10
    Membre expert
    Avatar de ericd69
    Homme Profil pro
    Développeur informatique
    Inscrit en
    Avril 2011
    Messages
    1 919
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Isère (Rhône Alpes)

    Informations professionnelles :
    Activité : Développeur informatique
    Secteur : High Tech - Multimédia et Internet

    Informations forums :
    Inscription : Avril 2011
    Messages : 1 919
    Points : 3 295
    Points
    3 295
    Billets dans le blog
    1
    Par défaut
    simple une jointure sur la table rubrique le fera:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
     
    SELECT v.id_ville,nom_ville,cp_ville ,longi,lati,
      get_distance_metres('".$lat."', '".$long."', lati, long) AS distance,
      nom_rubrique
    FROM table_villes v
    left join table_rubrique r on r.id_ville=v.id_ville
    WHERE get_distance_metres('".$lat."', '".$long."',  longi,lati)  BETWEEN 500 AND 7000
    tu es obligé de mettre des alias aux table car id_ville existe dans les 2 et il faut les distinguer...

    tu fais la jointure externe à gauche sur id_ville car c'est ton critère de rapatriement des données

    tu n'as donc plus qu'à rajouter le(s) nom(s) de(s) colonne(s) que tu veux récupéré dans la table jointe (en n'oubliant pas de préfixé les noms s'ils existent dans les 2 tables sous peine que mysql te dise qu'il ne peut les différencier avec une jolie erreur)
    soyons pensez à mettre quand votre problème est résolu ou à utiliser pour les réponses pertinentes...
    ne posez pas de problématique soi-disant simplifiée sur des problèmes que vous n'êtes pas capable de résoudre par respect pour ceux qui planchent dessus... sinon: et à utiliser pour insérer votre code...

  11. #11
    Membre habitué
    Profil pro
    Inscrit en
    Juin 2006
    Messages
    412
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Juin 2006
    Messages : 412
    Points : 145
    Points
    145
    Par défaut
    merci, ça fonctionne impeccable.

    au début j'avais essayé une jointure mais ça marchait pas ( sans doute erreur de syntaxe ou de logique )

    là c'est tout bon.

    grand merci

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

Discussions similaires

  1. Probleme de tri avec des sous requêtes
    Par kamnouz dans le forum Requêtes
    Réponses: 1
    Dernier message: 20/04/2010, 10h03
  2. [SQL Server] Probleme de sous-requête
    Par benthebest dans le forum Langage SQL
    Réponses: 5
    Dernier message: 26/02/2008, 14h55
  3. suppression avec sous requête conditionnelle
    Par melmel dans le forum Requêtes
    Réponses: 8
    Dernier message: 18/03/2004, 23h20
  4. petit probleme dans une requte POSTGRE SQL
    Par ghis le fou dans le forum Requêtes
    Réponses: 5
    Dernier message: 08/09/2003, 13h51
  5. Réponses: 3
    Dernier message: 18/05/2003, 00h16

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