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 :

Tester l'existence d'un champ [MySQL]


Sujet :

PHP & Base de données

  1. #1
    Membre à l'essai
    Profil pro
    Inscrit en
    Mai 2004
    Messages
    15
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Mai 2004
    Messages : 15
    Points : 13
    Points
    13
    Par défaut Tester l'existence d'un champ
    Bonjour,

    J'utilise dans une requête sql une variable pour indiquer sur quels champs effectuer la recherche , sous cette forme : $sql = "SELECT * FROM " . $table . " WHERE " . $field1 . " = '" . $val1 . "'";
    Le problème c'est que dans mon programme il se peut que la variable $field1 contienne un nom de champ qui n'existe pas, ce qui engendre un bug. Je recherche donc une instruction qui testerait l'existence de ce champ dans la BD.

    Quelqu'un peut-il m'aider ? Merci.

  2. #2
    Membre actif Avatar de frol
    Profil pro
    Inscrit en
    Mars 2005
    Messages
    288
    Détails du profil
    Informations personnelles :
    Âge : 35
    Localisation : Belgique

    Informations forums :
    Inscription : Mars 2005
    Messages : 288
    Points : 296
    Points
    296
    Par défaut
    sur un select quand il n'y a pas d'enregistrement il ne devrais pas avoir de message d'erreur.
    Quel est-il?

  3. #3
    Membre à l'essai
    Profil pro
    Inscrit en
    Mai 2004
    Messages
    15
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Mai 2004
    Messages : 15
    Points : 13
    Points
    13
    Par défaut
    Je n'ai pas parlé de message d'erreur d'ailleurs l'erreur n'est pas au niveau de php. En fait j'appelle le fichier php depuis une animation flash et c'est au niveau de l'animation flash que ça ne marche pas quand le champ n'existe pas. Enfin bref. Exite-t-il un moyen simple de vérifier si le champ existe ? Sinon j'ai pensé à un truc du style une boucle avec mysql_field_name...?

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

    Informations forums :
    Inscription : Juin 2003
    Messages : 10 359
    Points : 15 705
    Points
    15 705
    Par défaut
    dans le cas où la table est vide tu ne peux pas utiliser "mysql_field_name" si la table est vide
    par contre ce que tu peux faire c'est envoyer une requête "DESCRIBE" (http://dev.mysql.com/doc/refman/5.0/fr/describe.html) pour voir la structure de la table

  5. #5
    Membre à l'essai
    Profil pro
    Inscrit en
    Mai 2004
    Messages
    15
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Mai 2004
    Messages : 15
    Points : 13
    Points
    13
    Par défaut
    La table ne sera jamais vide. Je ne comprends pas comment utiliser la requêt DESCRIBE

  6. #6
    Membre à l'essai
    Profil pro
    Inscrit en
    Mai 2004
    Messages
    15
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Mai 2004
    Messages : 15
    Points : 13
    Points
    13
    Par défaut
    J'ai trouvé ce dont j'ai besoin c'est la requête SHOW COLUMNS, découverte dans le lien de Mathieu, ce qui donne :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
     
    $result = mysql_query("SHOW COLUMNS FROM " . $table);
     
    if (mysql_num_rows($result) > 0)
    {
    	while ($row = mysql_fetch_assoc($result))
    		print_r($row["Field"]);
    }

  7. #7
    Membre actif Avatar de frol
    Profil pro
    Inscrit en
    Mars 2005
    Messages
    288
    Détails du profil
    Informations personnelles :
    Âge : 35
    Localisation : Belgique

    Informations forums :
    Inscription : Mars 2005
    Messages : 288
    Points : 296
    Points
    296
    Par défaut
    bon oki j'avais rien compris a ta question sorry

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

Discussions similaires

  1. [PL/SQL] Comment tester l'existence d'un champ?
    Par nanou9999 dans le forum Oracle
    Réponses: 4
    Dernier message: 19/04/2012, 15h25
  2. Tester l'existence d'un champ dans une requête
    Par Reidid dans le forum Access
    Réponses: 3
    Dernier message: 23/01/2006, 22h02
  3. Tester l'existance d'un champ de formulaire .
    Par maxos75 dans le forum ASP
    Réponses: 3
    Dernier message: 21/12/2005, 12h47
  4. Tester l'existence d'un champ dans une table
    Par Oluha dans le forum MS SQL Server
    Réponses: 4
    Dernier message: 05/09/2005, 11h19
  5. Tester l'existence d'un champ
    Par Loko dans le forum Général JavaScript
    Réponses: 3
    Dernier message: 06/12/2004, 11h26

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