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

Langage PHP Discussion :

problème de condition


Sujet :

Langage PHP

  1. #1
    Membre confirmé

    Profil pro
    Inscrit en
    Août 2008
    Messages
    1 191
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Août 2008
    Messages : 1 191
    Points : 595
    Points
    595
    Par défaut problème de condition
    Bonjour a tous, j'ai un souci de condition, je n'arrive pas a trouvé la bonne solution, mon souci serai de chercher une valeur $id c'est une valeur récupéré dans un champs id_client de la table rdv, si elle existe je dis a php de chercher $id, si elle n'existe pas, je crée un $id qui correspond a une cellue de la table id_client et je redemande de lire cette valeur, mais je ne sais pas commen faire appare de mettre en boucle cette meme instruction voici le bout de script:

    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
    25
    26
    27
    28
    29
    30
    31
    32
    33
    34
    35
    36
    37
    38
     
    <?php
    //on recherche si le client exite?
    $select_client= 'SELECT * FROM _clients WHERE 
    nom = "'.$nom.'" AND phone = "'.$phone.'" ';
    echo $select_client;
    $sql_client= mysql_query ($select_client);
     
    //existe t'il?
    $id_count= mysql_num_rows($sql_client);
     
    if ($id_count=='0')
    	{
    	//si il ne trouve pas nom et telephone ,enregistrement client
    	 $add_client = "INSERT INTO _clients VALUES 
         ('', '$nom', '$adr', '$cp', '$ville', '$phone', '$mail')";
     
    	mysql_query ($add_client);
    	echo '<h1>enregistrement de julie</h1>';
     
            //fetch assoc de $sql_client pour recuperer l'id
    $assoc_client= mysql_fetch_assoc($sql_client);
    $id=$assoc_client['id_client'];
    echo $id;
    }
     
     
     
     
    else
    {	
    //fetch assoc de $sql_client pour recuperer l'id
    $assoc_client= mysql_fetch_assoc($sql_client);
    $id=$assoc_client['id_client'];
    echo $id;
    }
     
    ?>
    comment faire pour éviter de réutiliser ce bout de scipt?
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
     
    //fetch assoc de $sql_client pour recuperer l'id
    $assoc_client= mysql_fetch_assoc($sql_client);
    $id=$assoc_client['id_client'];
    echo $id;
    }
    si j'execute ce code:
    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
    25
    26
    27
    28
    29
    30
    31
    32
    33
    34
     
    <?php
    //on recherche si le client exite?
    $select_client= 'SELECT * FROM _clients WHERE 
    nom = "'.$nom.'" AND phone = "'.$phone.'" ';
    echo $select_client;
    $sql_client= mysql_query ($select_client);
     
    //existe t'il?
    $id_count= mysql_num_rows($sql_client);
     
    if ($id_count=='0')
    	{
    	//si il ne trouve pas nom et telephone ,enregistrement client
    	 $add_client = "INSERT INTO _clients VALUES 
         ('', '$nom', '$adr', '$cp', '$ville', '$phone', '$mail')";
     
    	mysql_query ($add_client);
    	echo '<h1>enregistrement du nouveau client</h1>';
     
    }
     
     
     
     
    else
    {	
    //fetch assoc de $sql_client pour recuperer l'id
    $assoc_client= mysql_fetch_assoc($sql_client);
    $id=$assoc_client['id_client'];
    echo $id;
    }
     
    ?>
    lorsque le client existe déjà la le champs id_rdv est bien remplis, si elle n'existe pas j'a cette erreur:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
     
    Notice: Undefined variable: id in C:\wamp\www\rdv\demande.php on line 145
    c'est tous a faire normal puisque qu'il ne sais la valeur $id , il remplis alors d'un 0

    voici la structure des tables au cas ou..
    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
    25
    26
    27
     
    -- Structure de la table `_clients`
    --
     
    CREATE TABLE IF NOT EXISTS `_clients` (
      `id_client` tinyint(3) unsigned NOT NULL AUTO_INCREMENT,
      `nom` varchar(20) NOT NULL,
      `adresse` varchar(100) NOT NULL,
      `cp` varchar(5) NOT NULL,
      `ville` varchar(25) NOT NULL,
      `phone` varchar(10) NOT NULL,
      `mail` varchar(100) NOT NULL,
      PRIMARY KEY (`id_client`)
    ) ENGINE=MyISAM  DEFAULT CHARSET=latin1 AUTO_INCREMENT=23 ;
     
    --
    -- Structure de la table `_rdvs`
    --
     
    CREATE TABLE IF NOT EXISTS `_rdvs` (
      `id_rdv` smallint(5) unsigned NOT NULL AUTO_INCREMENT,
      `id_client` smallint(5) unsigned NOT NULL,
      `timestamp` int(10) unsigned NOT NULL,
      `vu` tinyint(1) unsigned NOT NULL,
      `exposer` smallint(5) unsigned NOT NULL,
      PRIMARY KEY (`id_rdv`)
    ) ENGINE=MyISAM  DEFAULT CHARSET=latin1 AUTO_INCREMENT=19 ;
    merci de vos coup de pouce.

    merci de ton aide cela fonctionne

  2. #2
    Membre éclairé
    Avatar de djayp
    Profil pro
    Inscrit en
    Avril 2004
    Messages
    295
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Avril 2004
    Messages : 295
    Points : 687
    Points
    687
    Par défaut
    Salut !

    Il te suffit d'utiliser la fonction mysql_insert_id juste après l'ajout du nouveau client. Cette fonction renvoit en effet l'id généré lors de la dernière requête d'insertion.

    A++

  3. #3
    Membre confirmé

    Profil pro
    Inscrit en
    Août 2008
    Messages
    1 191
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Août 2008
    Messages : 1 191
    Points : 595
    Points
    595
    Par défaut
    merci de ta réponse pour mysql_insert_id
    j'ai essayé ceci:
    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
     
    $select_client= 'SELECT * FROM _clients WHERE 
    nom = "'.$nom.'" AND phone = "'.$phone.'" ';
    $sql_client= mysql_query ($select_client);
    //existe t'il?
    $id_count= mysql_num_rows($sql_client);
     
    if ($id_count=='0')
    	{
    	//si il ne trouve pas nom et telephone ,enregistrement client
    	 $add_client = "INSERT INTO _clients VALUES 
         ('', '$nom', '$adr', '$cp', '$ville', '$phone', '$mail')";
    	mysql_query ($add_client);
    	//on recherche l'id qui vien d'être enregistrer
    $newid=mysql_query($sql_client);
    $id= mysql_insert_id($newid));
    echo $id;
    echo "<br>";
     
    	 }
    il ne trouve toujour pas ma valeur $id;
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
     
    Notice: Undefined variable: id in C:\wamp\www\rdv\demande.php on line 147
    j'ai du mal l'utiliser ou dois -je mettre mysql_insert

  4. #4
    Membre émérite Avatar de Djakisback
    Profil pro
    Inscrit en
    Février 2005
    Messages
    2 023
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Février 2005
    Messages : 2 023
    Points : 2 273
    Points
    2 273
    Par défaut
    Salut,
    oui il faut que tu assignes la valeur et pas seulement que tu l'affiches :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    $id = mysql_insert_id();

  5. #5
    Membre confirmé

    Profil pro
    Inscrit en
    Août 2008
    Messages
    1 191
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Août 2008
    Messages : 1 191
    Points : 595
    Points
    595
    Par défaut
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
     
    	mysql_query ($sql_client);
    	//on recherche l'id qui vien d'être enregistrer
    $newid=mysql_query($sql_client);
    $id= mysql_insert_id($newid));
    echo $id;
    echo "<br>";

    j'ai essayé d'ajouter $sql_client mais même problème:
    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
     
     
    //on recherche si le client exite?
    $select_client= 'SELECT * FROM _clients WHERE 
    nom = "'.$nom.'" AND phone = "'.$phone.'" ';
    $sql_client= mysql_query ($select_client);
    //existe t'il?
    $id_count= mysql_num_rows($sql_client);
     
    if ($id_count=='0')
    	{
    	//si il ne trouve pas nom et telephone ,enregistrement client
    	 $add_client = "INSERT INTO _clients VALUES 
         ('', '$nom', '$adr', '$cp', '$ville', '$phone', '$mail')";
    	mysql_query ($sql_client);
    	//on recherche l'id qui vien d'être enregistrer
    $newid=mysql_query($sql_client);
    $id= mysql_insert_id($newid));
    echo $id;
    echo "<br>";
     
    	 }

  6. #6
    Membre émérite Avatar de Djakisback
    Profil pro
    Inscrit en
    Février 2005
    Messages
    2 023
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Février 2005
    Messages : 2 023
    Points : 2 273
    Points
    2 273
    Par défaut
    Oui sauf qu'il faut que tu vires ta requête qui sert à rien (et en plus écrase peut-être la valeur de retour de la fonction)
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
     
    mysql_query ($add_client);
    $id= mysql_insert_id();
    echo $id;
    echo "<br>";
    Pour être plus précis :

    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
     
    //on recherche si le client exite?
    $select_client= 'SELECT * FROM _clients WHERE 
    nom = "'.$nom.'" AND phone = "'.$phone.'" ';
    $sql_client= mysql_query ($select_client);
     
    if (mysql_num_rows($sql_client) === 0) 	{
    	//si il ne trouve pas nom et telephone ,enregistrement client
    	 $add_client = "INSERT INTO _clients VALUES 
         ('', '$nom', '$adr', '$cp', '$ville', '$phone', '$mail')";
    	mysql_query ($add_client);
    $id= mysql_insert_id();
     }
    else {
    $row = mysq_fetch_assoc($sql_client);
    $id = $row['id_client'];
    }
     
    echo $id;
    echo "<br>";

  7. #7
    Membre confirmé

    Profil pro
    Inscrit en
    Août 2008
    Messages
    1 191
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Août 2008
    Messages : 1 191
    Points : 595
    Points
    595
    Par défaut
    j'ai essayé de test le scipt mais il ne m'affiche pas $id qui vient d'être enregistrer
    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
     
    //on recherche si le client exite?
    $select_client= 'SELECT * FROM _clients WHERE 
    nom = "'.$nom.'" AND phone = "'.$phone.'" ';
    $sql_client= mysql_query ($select_client);
     
    if (mysql_num_rows($sql_client) === 0)
     
     {
    //si il ne trouve pas nom et telephone ,enregistrement client
    $add_client = "INSERT INTO _clients VALUES 
    ('', '$nom', '$adr', '$cp', '$ville', '$phone', '$mail')";
    mysql_query ($add_client);
     
    $id= mysql_insert_id();
    echo "<h1>$id'</h1>";
    }
    else
     {
    //fetch assoc de $sql_client pour recuperer l'id
    $row = mysq_fetch_assoc($sql_client);
    $id = $row['id_client'];
    echo $id;
    	 }
    j'ai ajoué echo $sql id, mais apparament il n'affiche pas la dernière id,
    pouquoi mettre = = = 0 ? trois égal

  8. #8
    Membre éclairé
    Avatar de djayp
    Profil pro
    Inscrit en
    Avril 2004
    Messages
    295
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Avril 2004
    Messages : 295
    Points : 687
    Points
    687
    Par défaut
    Salut !

    Le paramètre passé dans mysql_insert_id() doit correspondre à l'identifiant de la connexion MySQL ouverte. Autrement dit :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    $bd=mysql_connect('...','...','...'); // on ouvre la connexion tout en récupérant son identifiant
    mysql_select_db('mabase',$bd); // sélection de la base de données
     
    $add_client = "INSERT INTO _clients VALUES ('', '$nom', '$adr', '$cp', '$ville', '$phone', '$mail')";
     
    if(mysql_query ($add_client,$bd)) { 
       $id= mysql_insert_id($bd);
       echo $id;
    }
    else { 
       echo "Erreur lors de l'ajout";
    }
    A++

  9. #9
    Membre émérite Avatar de Djakisback
    Profil pro
    Inscrit en
    Février 2005
    Messages
    2 023
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Février 2005
    Messages : 2 023
    Points : 2 273
    Points
    2 273
    Par défaut
    Non en fait c'est optionnel comme pour la plupart des fonctions mysql, il prend la connexion courante :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    int mysql_insert_id  ([ resource $link_identifier  ] )

  10. #10
    Membre émérite Avatar de Djakisback
    Profil pro
    Inscrit en
    Février 2005
    Messages
    2 023
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Février 2005
    Messages : 2 023
    Points : 2 273
    Points
    2 273
    Par défaut
    Citation Envoyé par keokaz Voir le message
    j'ai essayé de test le scipt mais il ne m'affiche pas $id qui vient d'être enregistrer
    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
     
    //on recherche si le client exite?
    $select_client= 'SELECT * FROM _clients WHERE 
    nom = "'.$nom.'" AND phone = "'.$phone.'" ';
    $sql_client= mysql_query ($select_client);
     
    if (mysql_num_rows($sql_client) === 0)
     
     {
    //si il ne trouve pas nom et telephone ,enregistrement client
    $add_client = "INSERT INTO _clients VALUES 
    ('', '$nom', '$adr', '$cp', '$ville', '$phone', '$mail')";
    mysql_query ($add_client);
     
    $id= mysql_insert_id();
    echo "<h1>$id'</h1>";
    }
    else
     {
    //fetch assoc de $sql_client pour recuperer l'id
    $row = mysq_fetch_assoc($sql_client);
    $id = $row['id_client'];
    echo $id;
    	 }
    j'ai ajoué echo $sql id, mais apparament il n'affiche pas la dernière id,
    pouquoi mettre = = = 0 ? trois égal

    Tu mets 3 === pour tester la valeur et le type, tu peux en mettre que 2 si tu veux. ex :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
     
    $i = 0;
    $i == '0' return true
    $i === '0' return false
    $i === 0 return true
    T'est sûr que ton insert fonctionne ?
    ajoute des tests sur tes requêtes c'est plus propre, ex :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    mysql_query ($add_client) or die(mysq_error());
    Tu pourras les virer ensuite quand tu mettras tout en ligne.

  11. #11
    Membre confirmé

    Profil pro
    Inscrit en
    Août 2008
    Messages
    1 191
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Août 2008
    Messages : 1 191
    Points : 595
    Points
    595
    Par défaut
    merci de tes réponses voici ce que j'ai fait:
    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
    25
     
    //existe t'il?
    $id_count= mysql_num_rows($sql_client);
     
    if ($id_count=='0')
    	{
    	//si il ne trouve pas nom et telephone ,enregistrement client
    	 $add_client = "INSERT INTO _clients VALUES 
         ('', '$nom', '$adr', '$cp', '$ville', '$phone', '$mail')";
     
    	mysql_query ($add_client);
    	echo '<h1>enregistrement de julie</h1>';
    	$id=mysql_insert_id();
    	echo $id;
    	echo "@@@@@@@@@";
    	}
     
    else
    {	
    //fetch assoc de $sql_client pour recuperer l'id
    $assoc_client= mysql_fetch_assoc($sql_client);
    $id=$assoc_client['id_client'];
    echo "ID SERA ICIII§§§§§§§§§§§§§§!!!!!!!!!";
    echo $id;
    }
    les truc bizzar c'est pour voir que ca affiche bien l'id

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

Discussions similaires

  1. [débutant] problème de condition dans une requete
    Par banker dans le forum Access
    Réponses: 5
    Dernier message: 22/03/2006, 13h52
  2. Réponses: 7
    Dernier message: 27/02/2006, 18h04
  3. [Debutant]Problème de condition
    Par ghan77 dans le forum Langage
    Réponses: 9
    Dernier message: 13/12/2005, 15h20
  4. Problème de condition, je flanche..
    Par KibitO dans le forum Langage
    Réponses: 13
    Dernier message: 11/11/2005, 12h57
  5. Réponses: 6
    Dernier message: 17/08/2005, 12h38

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