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 :

Vérifier l'existence et récupérer l'id. [MySQL]


Sujet :

PHP & Base de données

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre éclairé
    Profil pro
    Inscrit en
    Mars 2009
    Messages
    389
    Détails du profil
    Informations personnelles :
    Âge : 36
    Localisation : France, Paris (Île de France)

    Informations forums :
    Inscription : Mars 2009
    Messages : 389
    Par défaut Vérifier l'existence et récupérer l'id.

    J'ai fait un script d'importation de données dans une base. Tout fonctionne, mais pour l'instant ça ne vérifie pas si un élément existe déjà.

    J'ai deux tables, societe et testeur. Un testeur est rattaché à une société.
    Une société peut avoir plusieurs testeurs.

    Comment faire pour tester si le nom de la société existe déjà (dans ce cas, je ne créerai société) et récupérer l'id (NumSociete) de celle-ci?

    Ensuite, je rattacherai la société existante au nouveau testeur.


  2. #2
    Membre confirmé
    Inscrit en
    Juillet 2009
    Messages
    33
    Détails du profil
    Informations forums :
    Inscription : Juillet 2009
    Messages : 33
    Par défaut
    une des solutions est de faire une ptite requete comme ca
    select count(*) from SOCIETE where ID_SOCIETE = "ton_ID_a_Verifi";

    si cest égale à un il existe.

  3. #3
    Membre éclairé
    Profil pro
    Inscrit en
    Mars 2009
    Messages
    389
    Détails du profil
    Informations personnelles :
    Âge : 36
    Localisation : France, Paris (Île de France)

    Informations forums :
    Inscription : Mars 2009
    Messages : 389
    Par défaut
    Merci, en suivant tes conseils j'ai fait comme ça :
    Code php : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
     
    $requete="SELECT COUNT NomSociete FROM societe_import WHERE NomSociete = $nomSoc";
    $res = mysql_query($requete);
    if(mysql_result($res) == 1);
         echo "société existante";

    Mais je ne suis pas sur que ça marche, et comment faire pour récupérer l'id de la société existante?

  4. #4
    Membre confirmé
    Inscrit en
    Juillet 2009
    Messages
    33
    Détails du profil
    Informations forums :
    Inscription : Juillet 2009
    Messages : 33
    Par défaut
    essaye un truc du genre
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
     
    $req ="select id_societe , count(distinct nom_societe)as nb_soc
    from societe where nom_societe= '".$ton_nom_de_societe."'";
     
    $resul = mysql_query($req) 
    $ligne = mysql_fetch_array($resul)
     
    /* est ce quelle existe? */
    if($ligne['nb_soc']=='1')
    {
    	/* l'ID de ma societe*/
    	$ligne['id_societe']
    }

  5. #5
    Membre éclairé
    Profil pro
    Inscrit en
    Mars 2009
    Messages
    389
    Détails du profil
    Informations personnelles :
    Âge : 36
    Localisation : France, Paris (Île de France)

    Informations forums :
    Inscription : Mars 2009
    Messages : 389
    Par défaut
    Merci de ton aide.

    J'ai fait comme indiqué :
    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
     
    $req ="SELECT NumSociete , COUNT(DISTINCT NomSociete)AS nbSoc
    	FROM societe WHERE NomSociete= '".$nomSoc."'";
    $res = mysql_query($req); 
    $row = mysql_fetch_array($res);
    /* est ce quelle existe? */
    if($row['nbSoc']=='1') {
            /* l'ID de ma societe*/
    	$numSoc=$row['NumSociete'];
    	echo "<br/>meme société<br/>";
    }
    else {
    	$sql="INSERT INTO societe_import (NomSociete, TypeSociete, DescriptionSociete, AdresseSociete)
    		VALUES ($nomSoc,$typeSoc,null,$adresseSoc)";
    	mysql_query($sql) or die ("<br />$sql<br /><strong>".mysql_error()."</strong>");
    	$numSoc=mysql_insert_id();
    }
    echo "numéro société: $numSoc";
    Mais ça ne passe jamais par la boucle...
    Pourtant, NomSoc est transmis au bon format quand je le récupère avec getcsv, et je l'entoure avec des ' (apostrophe) donc normalement, ça devrait fonctionner!

    Où est le problème?

  6. #6
    Membre confirmé
    Inscrit en
    Juillet 2009
    Messages
    33
    Détails du profil
    Informations forums :
    Inscription : Juillet 2009
    Messages : 33
    Par défaut
    salut,
    cest bizarre jai tester chez moi, le principe fonctionne très bien.
    as tu éssayé de tester tas requete dans MySql?
    Dis moi ce que ca renvoi, notamment le nbSoc

    Dans le if fais attention, transforme le $ligne['NUMSOCIETE'] en $row['NUMSOCIETE']

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

Discussions similaires

  1. Vérifier l'existence d'un cookie chez le client...
    Par HNT dans le forum Général JavaScript
    Réponses: 6
    Dernier message: 30/08/2005, 21h09
  2. Comment vérifier l'existence d'un répertoire ?
    Par Sydaze dans le forum Débuter
    Réponses: 2
    Dernier message: 30/06/2005, 11h34
  3. Réponses: 3
    Dernier message: 05/04/2005, 14h36
  4. Réponses: 3
    Dernier message: 24/06/2004, 11h23
  5. Vérifier l'existence d'un répertoire
    Par Crazyblinkgirl dans le forum ASP
    Réponses: 4
    Dernier message: 24/06/2004, 11h13

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