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

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre éprouvé

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

    Informations forums :
    Inscription : Août 2008
    Messages : 1 222
    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 chevronné
    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
    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 éprouvé

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

    Informations forums :
    Inscription : Août 2008
    Messages : 1 222
    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 Expert 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
    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 éprouvé

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

    Informations forums :
    Inscription : Août 2008
    Messages : 1 222
    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 Expert 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
    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>";

+ 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, 14h52
  2. Réponses: 7
    Dernier message: 27/02/2006, 19h04
  3. [Debutant]Problème de condition
    Par ghan77 dans le forum Langage
    Réponses: 9
    Dernier message: 13/12/2005, 16h20
  4. Problème de condition, je flanche..
    Par KibitO dans le forum Langage
    Réponses: 13
    Dernier message: 11/11/2005, 13h57
  5. Réponses: 6
    Dernier message: 17/08/2005, 13h38

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