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 si une entrée existe dans une table [MySQL]


Sujet :

PHP & Base de données

  1. #1
    Nouveau membre du Club
    Homme Profil pro
    physico-chimiste
    Inscrit en
    Avril 2016
    Messages
    49
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 41
    Localisation : France, Hauts de Seine (Île de France)

    Informations professionnelles :
    Activité : physico-chimiste

    Informations forums :
    Inscription : Avril 2016
    Messages : 49
    Points : 37
    Points
    37
    Par défaut vérifier si une entrée existe dans une table
    Bonjour,

    Mon problème est simple (je débute...). Je veux vérifier que la valeur de la variable $dès récupérée dans un formulaire (par l'intermédiaire d'une liste déroulante) n'est pas égale à une entrée déjà présente dans ma table qui s'appelle consommables.
    Mais voilà, que cette entrée existe ou pas dans la table, ma page m'affiche toujours "$dés existe" avec $dés qui prends la valeur de l'item sélectionné dans la liste du formulaire.

    Qu'ai-je mal écrit dans ce code ?

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    $résultat1 = $bdd->query('SELECT EXISTS (SELECT * FROM consommables WHERE désignation="'.$dés.'")');
     
     
    			if($résultat1) 
    			{ echo $dés." existe";
     
     
    			} 
    		else 
    			{
    				echo $dès." n'existe pas";
    			}
    Merci d'avance pour votre aide,

    David

  2. #2
    Expert éminent sénior
    Avatar de mathieu
    Profil pro
    Inscrit en
    Juin 2003
    Messages
    10 235
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Juin 2003
    Messages : 10 235
    Points : 15 532
    Points
    15 532
    Par défaut
    si vous utilisez mysqli, vous aurez toujours le même type d'objet en retour que la ligne existe ou pas :
    http://php.net/mysqli.query

    donc pour savoir si le texte est trouvé ou non, vous pouvez par exemple lire le nombre de résultat du SELECT principal avec la méthode suivante :
    http://php.net/mysqli-result.num-rows

  3. #3
    Modérateur
    Avatar de sabotage
    Homme Profil pro
    Inscrit en
    Juillet 2005
    Messages
    29 208
    Détails du profil
    Informations personnelles :
    Sexe : Homme

    Informations forums :
    Inscription : Juillet 2005
    Messages : 29 208
    Points : 44 155
    Points
    44 155
    Par défaut
    Tout d'abord je te déconseille d'utiliser des accents, aussi bien en PHP qu'en SQL.

    Pour ton code, il faut contrôler le résultat : query() sera vrai du moment que la requête n'a pas produit d'erreur.
    Ici j'utilise une requête préparée pour intégrer la valeur venant du formulaire sans risque de sécurité.
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    $sth = $bdd->prepare('SELECT EXISTS (SELECT * FROM consommables WHERE désignation= :des)');
    $sth->execute(array(':des'=>$des));
    $result = $sth->fetchColumn(); 
    if($resultat == 1) {
         echo htmlspecialchars($dés) . " existe";
    }
    else 
       {
        echo htmlspecialchars($dès) ." n'existe pas";
    }
    N'oubliez pas de consulter les FAQ PHP et les cours et tutoriels PHP

  4. #4
    Nouveau membre du Club
    Homme Profil pro
    physico-chimiste
    Inscrit en
    Avril 2016
    Messages
    49
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 41
    Localisation : France, Hauts de Seine (Île de France)

    Informations professionnelles :
    Activité : physico-chimiste

    Informations forums :
    Inscription : Avril 2016
    Messages : 49
    Points : 37
    Points
    37
    Par défaut
    Bonjour à tous les deux,

    je vous réponds tardivement (j'avais mis en standby ce projet), mais je voulais vous remercier pour vos réponses.
    Et merci pour le conseil pour les accents.

    David

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

Discussions similaires

  1. Vérifier si une colonne existe dans une table
    Par tamise dans le forum PL/SQL
    Réponses: 5
    Dernier message: 15/07/2013, 11h14
  2. Réponses: 2
    Dernier message: 30/04/2012, 00h25
  3. Vérifier si un enregistrement existe dans une table
    Par developpeur_débutant dans le forum PL/SQL
    Réponses: 4
    Dernier message: 08/06/2010, 12h05
  4. Vérifier si une modifié existe dans ma table
    Par hoangeric dans le forum Dreamweaver
    Réponses: 0
    Dernier message: 01/07/2009, 17h37

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