Publicité
+ Répondre à la discussion
Affichage des résultats 1 à 5 sur 5
  1. #1
    Membre actif Avatar de tomix
    Homme Profil pro Thomas Gottvalles
    Bidouilleur
    Inscrit en
    janvier 2008
    Messages
    118
    Détails du profil
    Informations personnelles :
    Nom : Homme Thomas Gottvalles
    Âge : 33
    Localisation : France, Yvelines (Île de France)

    Informations professionnelles :
    Activité : Bidouilleur
    Secteur : High Tech - Multimédia et Internet

    Informations forums :
    Inscription : janvier 2008
    Messages : 118
    Points : 174
    Points
    174

    Par défaut Variable et nom de colonne

    Bonsoir,

    J'essaye d'apprendre la POO PHP et PDO tant qu'à faire. J'ai un petit soucis avec ce dernier pour sélectionner les valeurs d'une table avec la clause WHERE.

    C'est pas possible de faire une requête du style :

    Code :
    1
    2
     
    SELECT * FROM table WHERE $colonne = $valeur
    J'ai essayé avec les requêtes préparées mais d'après la doc, impossible de mettre la variable $colonne pour sélectionner mes valeurs. Je comprend rien.

    Merci de m'aider

  2. #2
    Membre actif Avatar de tomix
    Homme Profil pro Thomas Gottvalles
    Bidouilleur
    Inscrit en
    janvier 2008
    Messages
    118
    Détails du profil
    Informations personnelles :
    Nom : Homme Thomas Gottvalles
    Âge : 33
    Localisation : France, Yvelines (Île de France)

    Informations professionnelles :
    Activité : Bidouilleur
    Secteur : High Tech - Multimédia et Internet

    Informations forums :
    Inscription : janvier 2008
    Messages : 118
    Points : 174
    Points
    174

    Par défaut

    J'ai essayé comme ça aussi avec une requête simple mais sans succès
    Code :
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
     
    public function lister($colonne, $valeur)
    {
    	$billets = array();
     
           	$requete = $this->_baseDonnees->query('SELECT id, titre, corps, categorie, date, mois, commentaire, image FROM billets WHERE'  . $colonne . ' = ' . $valeur);
     
           	while ($donnees = $requete->fetch(PDO::FETCH_ASSOC))
      	{
           	         $billets[] = new Billet($donnees);
      	}
     
            return $billets;
    }

  3. #3
    Expert Confirmé Avatar de Fench
    Homme Profil pro
    Chercheur en informatique
    Inscrit en
    mai 2002
    Messages
    2 348
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Groenland

    Informations professionnelles :
    Activité : Chercheur en informatique
    Secteur : Administration - Collectivité locale

    Informations forums :
    Inscription : mai 2002
    Messages : 2 348
    Points : 3 160
    Points
    3 160

    Par défaut

    Bonjour,

    Sur les requêtes dynamique tu as:
    Seules des valeurs peuvent faire l'objet de paramètres. Les noms SQL (colonnes, tables, bases, etc) ou mot-clés (asc/desc) en sont exclus. D'autant qu'ils se verraient ajoutés des quotes et on s'éloigne quelque peu de leur principe ...

    Donc, non, impossible de dynamiser ces parties de requêtes avec une requête préparée (il faut le faire avant la préparation ou avec une requête non préparée). (à se demander si des requêtes préparées sont ici utiles par ailleurs)
    Tu es donc obligé de faire avant le prepare dans ce cas comme par exemple:

    Code :
    1
    2
    3
    4
    5
    6
     
    $colonne = '...';
    $valeur = '....';
    $req = 'SELECT * FROM table WHERE '.$colonne.' = '.$valeur;
    $sql = $DB->prepare($sql);
    $sql->execute();
    Meuuh en AI à l'INRA
    Domaines: {java, php, js, jquery}{hibernate, doctrine}{MyLib, symfony, Zend}
    fait gagner du temps à ceux qui aident , donc un message avec la balise résolu laisse plus de temps pour résoudre d'autres problèmes (balise à cliquer en bas de l'écran)

  4. #4
    Membre expérimenté Avatar de LeGilou
    Profil pro
    Inscrit en
    octobre 2008
    Messages
    488
    Détails du profil
    Informations personnelles :
    Localisation : France, Ille et Vilaine (Bretagne)

    Informations forums :
    Inscription : octobre 2008
    Messages : 488
    Points : 500
    Points
    500

    Par défaut

    Salut,

    En complément de ce que dit Fench, tu peux utiliser les requêtes préparées de cette manière :

    Code :
    1
    2
    3
    4
    5
    6
    7
    8
     
    $colonne = '...';
    $valeur = '....';
     
    $req = "SELECT * FROM table WHERE ".$colonne." = :valeur";
    $sql = $DB->prepare($sql);
    $sql->bindValue(':valeur', $valeur, PDO::PARAM_STR); 
    $sql->execute();

  5. #5
    Membre actif Avatar de tomix
    Homme Profil pro Thomas Gottvalles
    Bidouilleur
    Inscrit en
    janvier 2008
    Messages
    118
    Détails du profil
    Informations personnelles :
    Nom : Homme Thomas Gottvalles
    Âge : 33
    Localisation : France, Yvelines (Île de France)

    Informations professionnelles :
    Activité : Bidouilleur
    Secteur : High Tech - Multimédia et Internet

    Informations forums :
    Inscription : janvier 2008
    Messages : 118
    Points : 174
    Points
    174

    Par défaut

    Ha merci j'ai compris

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

Liens sociaux

Règles de messages

  • Vous ne pouvez pas créer de nouvelles discussions
  • Vous ne pouvez pas envoyer des réponses
  • Vous ne pouvez pas envoyer des pièces jointes
  • Vous ne pouvez pas modifier vos messages
  •