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 :

aide requête dans mysql


Sujet :

Requêtes MySQL

  1. #1
    Futur Membre du Club
    Profil pro
    Inscrit en
    Février 2008
    Messages
    14
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Février 2008
    Messages : 14
    Points : 6
    Points
    6
    Par défaut aide requête dans mysql
    Bonjour,
    j'ai une base de données avec plusieurs tables sous mysql mon problème est le suivant:
    je vous donne un exemple:
    soit les tables :

    region{idregion,nom region,numeroregion}

    département{iddép,nomdépartement,numerodépartement,numeroregion}

    commune{idcom,nomcommune,identifiantcommune,numerodépartement}

    je voudrais savoir quelle est la requête SQL qu'il faut faire pour avoir le

    numeroregion à partir identifiantcommune
    merci d'avance.

  2. #2
    Expert confirmé Avatar de Cybher
    Homme Profil pro
    Consultant réseaux et sécurité
    Inscrit en
    Mai 2005
    Messages
    3 281
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 40
    Localisation : France

    Informations professionnelles :
    Activité : Consultant réseaux et sécurité
    Secteur : Conseil

    Informations forums :
    Inscription : Mai 2005
    Messages : 3 281
    Points : 4 641
    Points
    4 641
    Par défaut
    bonjour,

    ou est ce que tu bloques?
    regarde du côté des jointures : http://sql.developpez.com/sqlaz/jointures/

    bon courage

  3. #3
    ced
    ced est déconnecté
    Rédacteur/Modérateur

    Avatar de ced
    Homme Profil pro
    Gestion de bases de données techniques
    Inscrit en
    Avril 2002
    Messages
    6 016
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 48
    Localisation : France, Loiret (Centre)

    Informations professionnelles :
    Activité : Gestion de bases de données techniques
    Secteur : Agroalimentaire - Agriculture

    Informations forums :
    Inscription : Avril 2002
    Messages : 6 016
    Points : 23 705
    Points
    23 705
    Par défaut
    Bonjour,

    2 jointures internes : une entre commune et département sur numérodépartement, puis une entre département et région sur numérorégion.

    ced
    Rédacteur / Modérateur SGBD et R
    Mes tutoriels et la FAQ MySQL

    ----------------------------------------------------
    Pensez aux balises code et au tag
    Une réponse vous a plu ? N'hésitez pas à y mettre un
    Je ne réponds pas aux questions techniques par message privé, les forums sont là pour ça

  4. #4
    Futur Membre du Club
    Profil pro
    Inscrit en
    Février 2008
    Messages
    14
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Février 2008
    Messages : 14
    Points : 6
    Points
    6
    Par défaut
    merci pour vos réponses.
    en fait je suis débutatnt en sql et je ne m'y connais pas trop donc je voudrais savoir si je peux faire qu'une seule requête pour avoir le résultat voulu?

  5. #5
    Futur Membre du Club
    Profil pro
    Inscrit en
    Février 2008
    Messages
    14
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Février 2008
    Messages : 14
    Points : 6
    Points
    6
    Par défaut
    Citation Envoyé par ced Voir le message
    Bonjour,

    2 jointures internes : une entre commune et département sur numérodépartement, puis une entre département et région sur numérorégion.

    ced
    comment pourrais-je faire ça avec mon exemple?
    merci

  6. #6
    Membre du Club Avatar de LeBelge63
    Profil pro
    Étudiant
    Inscrit en
    Mai 2008
    Messages
    73
    Détails du profil
    Informations personnelles :
    Âge : 36
    Localisation : France, Puy de Dôme (Auvergne)

    Informations professionnelles :
    Activité : Étudiant

    Informations forums :
    Inscription : Mai 2008
    Messages : 73
    Points : 58
    Points
    58
    Par défaut
    Il te suffit juste de faire une jointure entre tes clé étrangere et tes clé primaires dans le WHERE de ta requete.

    ton MRD me parait bizare.

    region{idregion,nom region,numeroregion}

    département{iddép,nomdépartement,numerodépartement,numeroregion}

    commune{idcom,nomcommune,identifiantcommune,numerodépartement}

    Je pense qu'il serait plus approprié de faire :

    region{idregion,nom region,numeroregion}

    département{iddép,nomdépartement,numerodépartement,#idrégion}

    commune{idcom,nomcommune,identifiantcommune,#iddép}
    Pensez à utiliser

    est ton ami

    La France c'est l'Auvergne avec un petit peu de terre autour !!!

  7. #7
    Expert confirmé Avatar de Cybher
    Homme Profil pro
    Consultant réseaux et sécurité
    Inscrit en
    Mai 2005
    Messages
    3 281
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 40
    Localisation : France

    Informations professionnelles :
    Activité : Consultant réseaux et sécurité
    Secteur : Conseil

    Informations forums :
    Inscription : Mai 2005
    Messages : 3 281
    Points : 4 641
    Points
    4 641
    Par défaut
    une seule jointure devrait suffire :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    select numeroregion
    from departement inner join commune
    on departement.numerodepartement = commune.numerodepartement
    where identifiantcommune = 'XXX'

  8. #8
    Membre du Club Avatar de LeBelge63
    Profil pro
    Étudiant
    Inscrit en
    Mai 2008
    Messages
    73
    Détails du profil
    Informations personnelles :
    Âge : 36
    Localisation : France, Puy de Dôme (Auvergne)

    Informations professionnelles :
    Activité : Étudiant

    Informations forums :
    Inscription : Mai 2008
    Messages : 73
    Points : 58
    Points
    58
    Par défaut
    Moi je fait pas comme ca :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    SELECT numregion
              FROM departement.d, commune.c
              WHERE d.iddep = c.iddep
              AND idcommune = 'XXX';
    Aprés chacun sa methode.
    Pensez à utiliser

    est ton ami

    La France c'est l'Auvergne avec un petit peu de terre autour !!!

  9. #9
    ced
    ced est déconnecté
    Rédacteur/Modérateur

    Avatar de ced
    Homme Profil pro
    Gestion de bases de données techniques
    Inscrit en
    Avril 2002
    Messages
    6 016
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 48
    Localisation : France, Loiret (Centre)

    Informations professionnelles :
    Activité : Gestion de bases de données techniques
    Secteur : Agroalimentaire - Agriculture

    Informations forums :
    Inscription : Avril 2002
    Messages : 6 016
    Points : 23 705
    Points
    23 705
    Par défaut
    Citation Envoyé par LeBelge63 Voir le message
    Moi je fait pas comme ca :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    SELECT numregion
              FROM departement.d, commune.c
              WHERE d.iddep = c.iddep
              AND idcommune = 'XXX';
    Aprés chacun sa methode.
    C'est une écriture des jointures qui commence à dater un peu . La syntaxe de Cybher est quand même préférable, compatible avec la norme SQL92... Pour une seule jointure interne, ça n'a pas trop d'importance, mais quand on complexifie les requêtes, la syntaxe INNER JOIN est préférable (à mon humble avis).
    Autant prendre tout de suite de bonnes habitudes .

    ced
    Rédacteur / Modérateur SGBD et R
    Mes tutoriels et la FAQ MySQL

    ----------------------------------------------------
    Pensez aux balises code et au tag
    Une réponse vous a plu ? N'hésitez pas à y mettre un
    Je ne réponds pas aux questions techniques par message privé, les forums sont là pour ça

  10. #10
    Membre du Club Avatar de LeBelge63
    Profil pro
    Étudiant
    Inscrit en
    Mai 2008
    Messages
    73
    Détails du profil
    Informations personnelles :
    Âge : 36
    Localisation : France, Puy de Dôme (Auvergne)

    Informations professionnelles :
    Activité : Étudiant

    Informations forums :
    Inscription : Mai 2008
    Messages : 73
    Points : 58
    Points
    58
    Par défaut
    Pourtant je suis pas si vieux que ça
    Pensez à utiliser

    est ton ami

    La France c'est l'Auvergne avec un petit peu de terre autour !!!

  11. #11
    Futur Membre du Club
    Profil pro
    Inscrit en
    Février 2008
    Messages
    14
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Février 2008
    Messages : 14
    Points : 6
    Points
    6
    Par défaut
    Citation Envoyé par LeBelge63 Voir le message
    Il te suffit juste de faire une jointure entre tes clé étrangere et tes clé primaires dans le WHERE de ta requete.

    ton MRD me parait bizare.

    region{idregion,nom region,numeroregion}

    département{iddép,nomdépartement,numerodépartement,numeroregion}

    commune{idcom,nomcommune,identifiantcommune,numerodépartement}

    Je pense qu'il serait plus approprié de faire :

    region{idregion,nom region,numeroregion}

    département{iddép,nomdépartement,numerodépartement,#idrégion}

    commune{idcom,nomcommune,identifiantcommune,#iddép}
    merci pour toute vos réponses, j'ai toujour un message d'erreur que je vais essayer de régler "#1054 - Unknown column 'nom_region' in 'field list' "
    je voudrais savoir si en modifiant mes tables comme tu me l'a dit, je serais obligé de faire correspondre idrégion que tu m'as proposé par iddép et refaire tout le tableau? or moi j'ai fait en sorte de mettre le numero de région au lieu de idrégion car cela me permet de savoir directement à quel région appartient le département sans chercher tous les idregion correspondant, car je metterais encore plus de temps à faire ça.

Discussions similaires

  1. Réponses: 2
    Dernier message: 06/04/2010, 15h17
  2. [ZF 1.8] Connaître la requête dans une aide de vue
    Par Feng-Huang dans le forum MVC
    Réponses: 2
    Dernier message: 24/05/2009, 19h11
  3. aide pour construire une requête sur Mysql
    Par wagui26 dans le forum Débuter
    Réponses: 8
    Dernier message: 13/02/2009, 23h43
  4. Réponses: 4
    Dernier message: 13/11/2007, 22h23
  5. [MySQL] Aide requête MySQL : sélection aléatoire d'un enregistrement avec critère
    Par iwf-fr dans le forum PHP & Base de données
    Réponses: 6
    Dernier message: 07/05/2007, 09h01

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