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

PHP & Base de données Discussion :

Lien entre deux tables [MySQL]


Sujet :

PHP & Base de données

  1. #1
    Membre à l'essai
    Inscrit en
    Mars 2005
    Messages
    73
    Détails du profil
    Informations forums :
    Inscription : Mars 2005
    Messages : 73
    Points : 24
    Points
    24
    Par défaut Lien entre deux tables
    bonjour,
    j'ai deux table (table1 et table2) ayant un champ commun (nom)
    J'affiche sur une premiere pages toutes la table1 dont le champs "nom"
    et a partir du champ "nom" que j'affiche, je voudrai pouvoir ouvrir une nouvelle fenetre (via un lien hypertexte en cliquant sur le champs) avec cette foi si les champs de la table2 qui comporte aussi le champ "nom".
    Comment faire?
    Dsl si je n'ai pas été clair, je peut essayer si vous voulez d'eclairsir tout ca:


    bout de code pour la table1

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
      echo "<td><h5>".$row["nom"]."</td>";
    {
    $url = "affichage_detail_intervention.php?nomclient=afficher";
    echo ("<a href=\"".$url."\">afficher</a>");
    }
    ___________________________________________________________
    ce bout de code fait parti de la table2



    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    $connect=mysql_connect("...", "....", "") ;
        $select=mysql_select_db("complementaire");
     
    if (isset($_GET["nomclient"])) $nom=$_GET["nomclient"];
     
    $sql = ' SELECT DISTINCT telegestion_client.`nom`'
            . ' FROM telegestion_client'
            . ' JOIN complementaire'
            . ' ON telegestion_client.`nom` = complementaire.`nom`';

  2. #2
    Expert éminent Avatar de Mr N.
    Profil pro
    Inscrit en
    Septembre 2004
    Messages
    5 418
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Septembre 2004
    Messages : 5 418
    Points : 6 449
    Points
    6 449
    Par défaut
    Je te conseille plutoto d'utiliser un id (int) pour faire tes jointures. deux raisons majeures :
    1. plus rapides
    2. pas de problème de casses, d'accents & co...

    Ce qui reviendrait à faire =>
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    $sql = ' SELECT DISTINCT telegestion_client.nom'
    . ' FROM telegestion_client '
    . ' JOIN complementaire '
    . ' ON telegestion_client.id = complementaire.id ';
    WHERE telegestion_client.id = '.$id;

  3. #3
    Membre à l'essai
    Inscrit en
    Mars 2005
    Messages
    73
    Détails du profil
    Informations forums :
    Inscription : Mars 2005
    Messages : 73
    Points : 24
    Points
    24
    Par défaut lien entre deux tables
    oui mais pour le lien hypertexte sur "nom" dans la premiere page, comment faire? Car en fait je veu a partir du champ nom de ma premiere page, afficher les informations de l'autre tables qui contienne aussi le champs nom plus d'autre informations. Sachant que dans la deuxieme table j'ai plusieur foi le champs nom que l'on retrouve dedans car les informations sont multiple sur un client (différente intervention).
    Le probleme vien de ma liaison je suppose.

  4. #4
    Expert éminent Avatar de Mr N.
    Profil pro
    Inscrit en
    Septembre 2004
    Messages
    5 418
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Septembre 2004
    Messages : 5 418
    Points : 6 449
    Points
    6 449
    Par défaut
    C'est une très mauvaise chose de se baser sur le nom pour faire des liens entre les tables. Tu arriveras peut-être à résoudre momentanément ton problème actuelle, mais tu risque vite de déchanter...

    Tu affiches ta table 1 de noms dans page1 :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    <a href="page2.php?id=$id">$nom</a>
    Ainsi dans page2.php, on récupère l'id, seule manière fiable d'identifier quelqu'un (imagine les homonymes, les femmes qui se marient et qui change donc de noms...)
    Ensuite tu fais la requète comme proposée plus haut.

  5. #5
    Membre à l'essai
    Inscrit en
    Mars 2005
    Messages
    73
    Détails du profil
    Informations forums :
    Inscription : Mars 2005
    Messages : 73
    Points : 24
    Points
    24
    Par défaut merci
    Merci bien pour ton aide.
    juste un truc. Comment puis je faire pour mettre le message en resolut?

  6. #6
    Expert éminent Avatar de Mr N.
    Profil pro
    Inscrit en
    Septembre 2004
    Messages
    5 418
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Septembre 2004
    Messages : 5 418
    Points : 6 449
    Points
    6 449
    Par défaut
    en bas à droite un ch'tit bouton

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

Discussions similaires

  1. si pas de lien entre deux table
    Par acipeg dans le forum SAP Crystal Reports
    Réponses: 3
    Dernier message: 24/11/2006, 10h33
  2. [débutant] lien entre deux tables
    Par t-die dans le forum Débuter
    Réponses: 1
    Dernier message: 03/02/2006, 20h36
  3. lien entre deux table
    Par ept35 dans le forum Débuter
    Réponses: 28
    Dernier message: 21/12/2005, 14h50
  4. [MySQL] Lien entre deux tables
    Par ept35 dans le forum PHP & Base de données
    Réponses: 27
    Dernier message: 14/12/2005, 19h42
  5. [VB.NET] ComboBox lien entre deux tables
    Par VDB1 dans le forum Windows Forms
    Réponses: 3
    Dernier message: 15/07/2004, 12h15

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