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 :

Undefined variable: SPDO


Sujet :

PHP & Base de données

  1. #1
    Membre éclairé Avatar de dancom5
    Homme Profil pro
    Inscrit en
    Janvier 2010
    Messages
    808
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 56

    Informations forums :
    Inscription : Janvier 2010
    Messages : 808
    Par défaut Undefined variable: SPDO
    Bonjour. Je n'arrive pas à faire afficher ma requête. Quelque chose dans la class qui ne fonctionne pas.

    erreur : Undefined variable: SPDO
    Call to a member function dbSelect() on a non-object
    Quelqu'un peut m'aider à corriger?


    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
    19
    20
    21
    22
    23
    24
    25
    26
    27
    28
    29
    30
    31
    32
    33
    34
    35
    36
    37
    38
    39
    40
    41
    42
    43
    44
    45
    46
    47
    48
    49
    50
    51
    52
    53
    54
    55
    56
    57
    58
    59
    60
    61
    62
    63
    64
    65
    66
    67
    68
    69
    70
    71
    72
    73
    74
    75
    76
    77
    78
    79
    80
    81
    82
    83
    84
    85
    86
    87
    88
    89
    90
    91
    92
    93
    94
    95
    96
    97
    <?php
    class SPDO
    {
      private $PDOInstance = null;
      private static $instance = null;
      const DEFAULT_SQL_USER = 'bdd';
      const DEFAULT_SQL_HOST = 'localhost';
      const DEFAULT_SQL_PASS = 'bdd';
      const DEFAULT_SQL_DTB = 'bdd';
     
      private function __construct()
      {
        $this->PDOInstance = new PDO('mysql:dbname='.self::DEFAULT_SQL_DTB.';host='.self::DEFAULT_SQL_HOST,self::DEFAULT_SQL_USER ,self::DEFAULT_SQL_PASS);    
      }
     
      public static function getInstance()
      {  
        if(is_null(self::$instance))
        {
          self::$instance = new SPDO();
        }
        return self::$instance;
      }
     
      public function query($query)
      {
        return $this->PDOInstance->query($query);
      }
     
                public function dbSelect($table, $fieldname=null, $id=null)
                {
                        $sql = "SELECT * FROM `$table` WHERE `$fieldname`=:id";
                        $stmt = SPDO::getInstance()->prepare($sql);
                        $stmt->bindParam(':id', $id);
                        $stmt->execute();
                        return $stmt->fetchAll(PDO::FETCH_ASSOC);
                }
     
                public function rawSelect($sql)
                {
                        return SPDO::getInstance()->query($sql);
                }
     
                public function rawQuery($sql)
                {
                        SPDO::getInstance()->query($sql);
                }
     
                public function dbInsert($table, $values)
                {
                        /*** snarg the field names from the first array member ***/
                        $fieldnames = array_keys($values[0]);
                        /*** now build the query ***/
                        $size = sizeof($fieldnames);
                        $i = 1;
                        $sql = "INSERT INTO $table";
                        /*** set the field names ***/
                        $fields = '( ' . implode(' ,', $fieldnames) . ' )';
                        /*** set the placeholders ***/
                        $bound = '(:' . implode(', :', $fieldnames) . ' )';
                        /*** put the query together ***/
                        $sql .= $fields.' VALUES '.$bound;
     
                        /*** prepare and execute ***/
                        $stmt = SPDO::getInstance()->prepare($sql);
                        foreach($values as $vals)
                        {
                                $stmt->execute($vals);
                        }
                }
     
                public function dbUpdate($table, $fieldname, $value, $pk, $id)
                {
                        $sql = "UPDATE `$table` SET `$fieldname`='{$value}' WHERE `$pk` = :id";
                        $stmt = SPDO::getInstance()->prepare($sql);
                        $stmt->bindParam(':id', $id, PDO::PARAM_STR);
                        $stmt->execute();
                }
     
                public function dbDelete($table, $fieldname, $id)
                {
                        $sql = "DELETE FROM `$table` WHERE `$fieldname` = :id";
                        $stmt = SPDO::getInstance()->prepare($sql);
                        $stmt->bindParam(':id', $id, PDO::PARAM_STR);
                        $stmt->execute();
                }
     
    }
     
        $res = $SPDO->dbSelect('mpages', 'contenu', 3 );
     
        foreach($res as $row)
        {
            echo $row['contenu'];
        }
     
    ?>

  2. #2
    Expert confirmé
    Avatar de rawsrc
    Homme Profil pro
    Dev indep
    Inscrit en
    Mars 2004
    Messages
    6 142
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 48
    Localisation : France, Bouches du Rhône (Provence Alpes Côte d'Azur)

    Informations professionnelles :
    Activité : Dev indep

    Informations forums :
    Inscription : Mars 2004
    Messages : 6 142
    Billets dans le blog
    12
    Par défaut
    Salut,

    quand tu fais ceci :
    tu renvoies une instance de SPDO mais pas de PDO, en conséquence pas de ->prepare() sur l'instance SPDO.

    Reprends ton code autrement de manière à renvoyer du PDO

  3. #3
    Membre éclairé Avatar de dancom5
    Homme Profil pro
    Inscrit en
    Janvier 2010
    Messages
    808
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 56

    Informations forums :
    Inscription : Janvier 2010
    Messages : 808
    Par défaut
    J'ai remplacé SPDO par PDO.
    Même problème.


    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
    19
    20
    21
    22
    23
    24
    25
    26
    27
    28
    29
    30
    31
    32
    33
    34
    35
    36
    37
    38
    39
    40
    41
    42
    43
    44
    45
    46
    47
    48
    49
    50
    51
    52
    53
    54
    55
    56
    57
    58
    59
    60
    61
    62
    63
    64
    65
    66
    67
    68
    69
    70
    71
    72
    73
    74
    75
    76
    77
    78
    79
    80
    81
    82
    83
    84
    85
    86
    87
    88
    89
    90
    91
    92
    93
    94
    95
    96
    97
    <?php
    class SPDO
    {
      private $PDOInstance = null;
      private static $instance = null;
      const DEFAULT_SQL_USER = 'bdd';
      const DEFAULT_SQL_HOST = 'localhost';
      const DEFAULT_SQL_PASS = 'bdd';
      const DEFAULT_SQL_DTB = 'bdd';
     
      private function __construct()
      {
        $this->PDOInstance = new PDO('mysql:dbname='.self::DEFAULT_SQL_DTB.';host='.self::DEFAULT_SQL_HOST,self::DEFAULT_SQL_USER ,self::DEFAULT_SQL_PASS);    
      }
     
      public static function getInstance()
      {  
        if(is_null(self::$instance))
        {
          self::$instance = new SPDO();
        }
        return self::$instance;
      }
     
      public function query($query)
      {
        return $this->PDOInstance->query($query);
      }
     
                public function dbSelect($table, $fieldname=null, $id=null)
                {
                        $sql = "SELECT * FROM `$table` WHERE `$fieldname`=:id";
                        $stmt = PDO::getInstance()->prepare($sql);
                        $stmt->bindParam(':id', $id);
                        $stmt->execute();
                        return $stmt->fetchAll(PDO::FETCH_ASSOC);
                }
     
                public function rawSelect($sql)
                {
                        return PDO::getInstance()->query($sql);
                }
     
                public function rawQuery($sql)
                {
                        PDO::getInstance()->query($sql);
                }
     
                public function dbInsert($table, $values)
                {
                        /*** snarg the field names from the first array member ***/
                        $fieldnames = array_keys($values[0]);
                        /*** now build the query ***/
                        $size = sizeof($fieldnames);
                        $i = 1;
                        $sql = "INSERT INTO $table";
                        /*** set the field names ***/
                        $fields = '( ' . implode(' ,', $fieldnames) . ' )';
                        /*** set the placeholders ***/
                        $bound = '(:' . implode(', :', $fieldnames) . ' )';
                        /*** put the query together ***/
                        $sql .= $fields.' VALUES '.$bound;
     
                        /*** prepare and execute ***/
                        $stmt = PDO::getInstance()->prepare($sql);
                        foreach($values as $vals)
                        {
                                $stmt->execute($vals);
                        }
                }
     
                public function dbUpdate($table, $fieldname, $value, $pk, $id)
                {
                        $sql = "UPDATE `$table` SET `$fieldname`='{$value}' WHERE `$pk` = :id";
                        $stmt = PDO::getInstance()->prepare($sql);
                        $stmt->bindParam(':id', $id, PDO::PARAM_STR);
                        $stmt->execute();
                }
     
                public function dbDelete($table, $fieldname, $id)
                {
                        $sql = "DELETE FROM `$table` WHERE `$fieldname` = :id";
                        $stmt = PDO::getInstance()->prepare($sql);
                        $stmt->bindParam(':id', $id, PDO::PARAM_STR);
                        $stmt->execute();
                }
     
    }
     
        $res = $PDO->dbSelect('mpages', 'contenu', 3 );
     
        foreach($res as $row)
        {
            echo $row['contenu'];
        }
     
    ?>

  4. #4
    Expert confirmé
    Avatar de rawsrc
    Homme Profil pro
    Dev indep
    Inscrit en
    Mars 2004
    Messages
    6 142
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 48
    Localisation : France, Bouches du Rhône (Provence Alpes Côte d'Azur)

    Informations professionnelles :
    Activité : Dev indep

    Informations forums :
    Inscription : Mars 2004
    Messages : 6 142
    Billets dans le blog
    12
    Par défaut
    Euh, tu lis ce que t'écris ?
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    $stmt = PDO::getInstance()
    Où t'as dans ton code PDO ?
    Tu aurais dû faire comme ça :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    $stmt = $this->PDOInstance->prepare($sql);

Discussions similaires

  1. Undefined variable: Idclic
    Par kratos59 dans le forum Langage
    Réponses: 7
    Dernier message: 11/05/2006, 16h50
  2. Notice: Undefined variable
    Par oranoutan dans le forum Langage
    Réponses: 19
    Dernier message: 21/12/2005, 22h28
  3. undefined variable
    Par ept35 dans le forum Langage
    Réponses: 3
    Dernier message: 30/11/2005, 15h48
  4. Notice: Undefined variable
    Par kayn dans le forum Langage
    Réponses: 2
    Dernier message: 03/10/2005, 20h44
  5. Réponses: 3
    Dernier message: 22/09/2005, 11h24

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