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

Langage PHP Discussion :

Insertion d'une connection PDO sous une fonction [PHP 5.3]


Sujet :

Langage PHP

  1. #1
    Candidat au Club
    Homme Profil pro
    Développeur Web
    Inscrit en
    Avril 2012
    Messages
    2
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Ille et Vilaine (Bretagne)

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

    Informations forums :
    Inscription : Avril 2012
    Messages : 2
    Points : 3
    Points
    3
    Par défaut Insertion d'une connection PDO sous une fonction
    Bonjour a tous !
    Je viens vous demandez de l'aide car débutant avec PDO, je rame encore un peu malgrès mes recherches.
    Donc voila j'ai une fonction type:

    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
    function connectbase(){
    mysql_connect('localhost','root','mdp');
    mysql_select_db('mabase');
    }
     
    je souhaite y insérer une connection PDO :
     
    function connectbase(){
    try{
    $pdo_options[PDO::ATTR_ERRMODE] = PDO::ERRMODE_EXCEPTION;
    $bdd = new PDO('mysql:host=localhost;dbname=mabase', 'root', 'mdp', $pdo_options) ;
    }
     
    catch(Exception $e){
    die ('Erreur : ' . $e->getMessage());
    }
    }
    Evidemment sa ne fonctionne pas , je sais pas pourquoi encore !? si vous pouviez m'éclairer sur le sujet .
    Vous remerciant par avance de l'attention que vous pourriez y porter.

  2. #2
    Expert éminent sénior

    Profil pro
    Inscrit en
    Septembre 2010
    Messages
    7 920
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Septembre 2010
    Messages : 7 920
    Points : 10 727
    Points
    10 727

  3. #3
    Expert éminent
    Avatar de Benjamin Delespierre
    Profil pro
    Développeur Web
    Inscrit en
    Février 2010
    Messages
    3 929
    Détails du profil
    Informations personnelles :
    Âge : 36
    Localisation : France, Alpes Maritimes (Provence Alpes Côte d'Azur)

    Informations professionnelles :
    Activité : Développeur Web
    Secteur : High Tech - Opérateur de télécommunications

    Informations forums :
    Inscription : Février 2010
    Messages : 3 929
    Points : 7 762
    Points
    7 762
    Par défaut
    La référence à ton instance PDO n'est pas retournée par la fonction, elle est donc perdue à la sortie de celle-ci.

    Par ailleurs, tu ne dois pas utiliser les fonctions mysql_* et PDO dans le même temps, tout ce que tu peux faire avec mysql_* n'est pas pris en compte par PDO et vice versa.

    Si tu veux absolument utiliser une fonction connectbase (bien que je doute fortement de son utilité) tu peux lui donner cette forme (le paramètre $bdd est un paramètre de sortie):
    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
    function connectbase (& $bdd= null) {
      try{
        $pdo_options[PDO::ATTR_ERRMODE] = PDO::ERRMODE_EXCEPTION;
        $bdd = new PDO('mysql:host=localhost;dbname=mabase', 'root', 'mdp',     $pdo_options);
      }
      catch(Exception $e){
        return false;
      }
      return true;
    }
     
    // initialiser
    if (!connectbase($bdd)) {
      die("Cannot open database connection");
    }
     
    $bdd->query('...');

  4. #4
    Candidat au Club
    Homme Profil pro
    Développeur Web
    Inscrit en
    Avril 2012
    Messages
    2
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Ille et Vilaine (Bretagne)

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

    Informations forums :
    Inscription : Avril 2012
    Messages : 2
    Points : 3
    Points
    3
    Par défaut Merci beaucoup, a vous deux.
    Effectivement si j'ai bien compris , ce qui est à prendre en compte dans mon cas , est la portée de ma variable $bdd qui sans être définit dans mes paramètres disparait.
    est-ce bien cela?

  5. #5
    Expert éminent sénior

    Avatar de FirePrawn
    Homme Profil pro
    Consultant technique
    Inscrit en
    Mars 2011
    Messages
    3 179
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 36
    Localisation : France, Haut Rhin (Alsace)

    Informations professionnelles :
    Activité : Consultant technique

    Informations forums :
    Inscription : Mars 2011
    Messages : 3 179
    Points : 19 373
    Points
    19 373
    Par défaut
    Le problème c'est que ta fonction ne retourne rien.

    Comme l'a dit Benjamin, si tu veux pouvoir utiliser ta variable $bdd, il faut que ta fonction la renvoie, sinon comment veux-tu y accéder hors de ta fonction ?

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

Discussions similaires

  1. [MySQL] Insertion de données me parvenant sous une forme "sérialisée"
    Par mr_walid07 dans le forum PHP & Base de données
    Réponses: 1
    Dernier message: 10/05/2008, 16h23
  2. Réponses: 2
    Dernier message: 23/04/2007, 00h10
  3. mise a jour d'une table paradox avec une autre table sous delphi
    Par bobo2005 dans le forum Bases de données
    Réponses: 2
    Dernier message: 08/01/2007, 21h07
  4. copie d'une table Y d'une base A vers une table X d'une base
    Par moneyboss dans le forum PostgreSQL
    Réponses: 1
    Dernier message: 30/08/2005, 21h24

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