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 :

Utilisation de PDO et bindParam() [PDO]


Sujet :

PHP & Base de données

  1. #1
    Membre confirmé Avatar de wd_newbie
    Homme Profil pro
    Développeur
    Inscrit en
    Mars 2007
    Messages
    723
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Suisse

    Informations professionnelles :
    Activité : Développeur
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Mars 2007
    Messages : 723
    Points : 627
    Points
    627
    Par défaut Utilisation de PDO et bindParam()
    Bonsoir,

    je suis en train de mettre a jour quelques anciennes classe en utilisant PDO pour me connecter a MySQL.

    Un truc qui me prend la tête c'est que je n'arrive pas a utiliser les bindParam pour préparer mes requêtes ...

    Si je fais :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    		$stmt = $this->connection->prepare("SELECT * FROM users WHERE users_login LIKE 'myname'");
    			$stmt->bindParam(':login', $user , PDO::PARAM_STR);
    			$stmt->execute();
    			return $stmt->fetchAll(PDO::FETCH_ASSOC);
    j'ai bien les données de l'utilisateur qui est affichée avec la valeur de retour.

    Par conte avec ce code :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
     
    			$user="myname";
    			$stmt = $this->connection->prepare("SELECT * FROM users WHERE users_login LIKE ':login'");
    			$stmt->bindParam(':login', $user , PDO::PARAM_STR);
    			$stmt->execute();
    			return $stmt->fetchAll(PDO::FETCH_ASSOC);
    ... me renvoie toujours un tableau vide ... c'est rageant, j'ai beau essayer tous les tutos en ligne , rien ne passe ...

    Une idée ??

  2. #2
    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
    Pas de guillemet aux paramètres :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    $stmt = $this->connection->prepare("SELECT * FROM users WHERE users_login LIKE :login");
    N'oubliez pas de consulter les FAQ PHP et les cours et tutoriels PHP

  3. #3
    Expert éminent sénior

    Homme Profil pro
    Développeur Web
    Inscrit en
    Septembre 2010
    Messages
    5 380
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Puy de Dôme (Auvergne)

    Informations professionnelles :
    Activité : Développeur Web
    Secteur : High Tech - Multimédia et Internet

    Informations forums :
    Inscription : Septembre 2010
    Messages : 5 380
    Points : 10 410
    Points
    10 410
    Par défaut
    Au passage, c'est souvent assez fastidieux d'associer les valeurs avec bindParam. On gagne du temps en passant un tableau dans le execute() c'est plus pratique et accepte les marqueurs nommés ou interrogatifs.
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
     
    $stmt = $this->connection->prepare("SELECT * FROM users WHERE users_login LIKE :login");
    $stmt->execute(['login'=>$user]);
    //ou
    $stmt = $this->connection->prepare("SELECT * FROM users WHERE users_login LIKE ?");
    $stmt->execute([$user]);

  4. #4
    Modératrice
    Avatar de Celira
    Femme Profil pro
    Développeuse PHP/Java
    Inscrit en
    Avril 2007
    Messages
    8 633
    Détails du profil
    Informations personnelles :
    Sexe : Femme
    Âge : 39
    Localisation : France

    Informations professionnelles :
    Activité : Développeuse PHP/Java
    Secteur : Industrie

    Informations forums :
    Inscription : Avril 2007
    Messages : 8 633
    Points : 16 372
    Points
    16 372
    Par défaut
    sur ABCIWEB. Personnellement, la seule utilisation de bindParam que je vois, c'est pour exécuter une requête en boucle (avec la variable liée qui change à chaque tour de boucle), et ça se fait également très bien avec le tableau dans execute :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    $stmt = $pdo->prepare('select * from la_table where colonne = :param');
    $stmt->bindParam(':param', $param);
    foreach ($data as $param) {
        $stmt->execute();
        // ....
    }
    ou
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    $stmt = $pdo->prepare('select * from la_table where colonne = :param');
    foreach ($data as $param) {
        $stmt->execute(array(':param' => $param));
        // ....
    }
    Modératrice PHP
    Aucun navigateur ne propose d'extension boule-de-cristal : postez votre code et vos messages d'erreurs. (Rappel : "ça ne marche pas" n'est pas un message d'erreur)
    Cherchez un peu avant poser votre question : Cours et Tutoriels PHP - FAQ PHP - PDO une soupe et au lit !.

    Affichez votre code en couleurs : [CODE=php][/CODE] (bouton # de l'éditeur) et [C=php][/C]

  5. #5
    Membre confirmé Avatar de wd_newbie
    Homme Profil pro
    Développeur
    Inscrit en
    Mars 2007
    Messages
    723
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Suisse

    Informations professionnelles :
    Activité : Développeur
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Mars 2007
    Messages : 723
    Points : 627
    Points
    627
    Par défaut
    Bam ... sans les guillemets ça marche mieux

    Merci pour tout et je vais me pencher sur les autres conseils avisés des post !

    Excellente fin d'année

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

Discussions similaires

  1. [Système] PDO et bindParam() erreur.
    Par Rohann dans le forum Langage
    Réponses: 1
    Dernier message: 08/09/2006, 18h18
  2. [SQL] [php] PDO - fonction BindParam
    Par fadeninev dans le forum PHP & Base de données
    Réponses: 9
    Dernier message: 23/06/2006, 15h36
  3. [Sécurité] Failles PHP utilisés par le fishing
    Par neXistPa dans le forum Langage
    Réponses: 7
    Dernier message: 11/04/2006, 13h59
  4. [POO] BUG PHP ?? Utilisation référence
    Par aurapp dans le forum Langage
    Réponses: 6
    Dernier message: 04/04/2006, 14h25
  5. [PHP] Utilisation de XmlHttpRequest
    Par siddh dans le forum XML/XSL et SOAP
    Réponses: 2
    Dernier message: 17/11/2005, 07h47

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