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 :

Exécution d'une requête dans une fonction


Sujet :

PHP & Base de données

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre à l'essai
    Homme Profil pro
    Développeur multimédia
    Inscrit en
    Octobre 2023
    Messages
    4
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Pas de Calais (Nord Pas de Calais)

    Informations professionnelles :
    Activité : Développeur multimédia
    Secteur : Associations - ONG

    Informations forums :
    Inscription : Octobre 2023
    Messages : 4
    Par défaut Exécution d'une requête dans une fonction
    Bonsoir

    J'exécute des requêtes sur la une page PHP et ça fonctionne sans problème.
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
     $sqlQuery = "SELECT * from ccc_parcours  ";
    $sqlQuery .= "WHERE PAR_ID = ".$calendrier['CAL_LIEN'];
    //print $sqlQuery ;
    $parcourssStatement = $mysqlClient->prepare($sqlQuery);
    $parcourssStatement->execute();
    $parcourss = $parcourssStatement->fetchAll();
    // On affiche le nom du parcours
    foreach ($parcourss as $parcours) {print $parcours['PAR_NOM'];}

    Mais lorsque je veux exécuter cette requête dans une fonction, j'ai un message d'erreur:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    function AfficheAssociation($id) {
    $sqlQuery = "SELECT * from ccc_parcours* ";
    $sqlQuery .= "WHERE PAR_ID = ".$id;
    //print $sqlQuery ;
    $parcourssStatement = $mysqlClient->prepare($sqlQuery);
    $parcourssStatement->execute();
    $parcourss = $parcourssStatement->fetchAll();
    // On affiche le nom du parcours
    foreach ($parcourss as $parcours){print $parcours['PAR_NOM'];}
    } // Fin de AfficheAssociation

    Et dans le code PHP, j'appelle ma fonction
    Et voici le message d'erreur
    Call to a member function prepare() on null

    Quelqu'un peut m'aider?
    Merci

  2. #2
    Responsable Systèmes


    Homme Profil pro
    Gestion de parcs informatique
    Inscrit en
    Août 2011
    Messages
    18 256
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : Gestion de parcs informatique
    Secteur : High Tech - Matériel informatique

    Informations forums :
    Inscription : Août 2011
    Messages : 18 256
    Par défaut
    Je ne vois aucune trace de $mysqlclient dans la fonction.
    Ma page sur developpez.com : http://chrtophe.developpez.com/ (avec mes articles)
    Mon article sur le P2V, mon article sur le cloud
    Consultez nos FAQ : Windows, Linux, Virtualisation

  3. #3
    Membre à l'essai
    Homme Profil pro
    Développeur multimédia
    Inscrit en
    Octobre 2023
    Messages
    4
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Pas de Calais (Nord Pas de Calais)

    Informations professionnelles :
    Activité : Développeur multimédia
    Secteur : Associations - ONG

    Informations forums :
    Inscription : Octobre 2023
    Messages : 4
    Par défaut
    L'objet est mis à part
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
     $host_name = '****.hosting-data.io';
      $database = '*****';
      $user_name = '****';
      $password = '*****';
     
    $mysqlClient= null;
     
    try {
    $mysqlClient = new PDO("mysql:host=$host_name; dbname=$database;", $user_name, $password);
    //print "connexion réussie";
    } catch (PDOException $e) {
    echo "Erreur!:" . $e->getMessage();
    die();
    }
    Justement, faut il passer les paramètres à la fonction pour recréer un PDO (PHP Data Objects) dans la fonction? Parce que ça ne ma parait pas très optimisé, ça, créer 100000 objets quand on appelle 100000 fois la fonction ....

  4. #4
    Expert confirmé
    Avatar de Séb.
    Profil pro
    Inscrit en
    Mars 2005
    Messages
    5 320
    Détails du profil
    Informations personnelles :
    Âge : 47
    Localisation : France

    Informations professionnelles :
    Secteur : High Tech - Opérateur de télécommunications

    Informations forums :
    Inscription : Mars 2005
    Messages : 5 320
    Billets dans le blog
    17
    Par défaut
    Il faut passer $mysqlClient en paramètre à la fonction.

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    function AfficheAssociation($mysqlClient, $id) {
        ...

  5. #5
    Expert confirmé Avatar de Toufik83
    Homme Profil pro
    Développeur informatique
    Inscrit en
    Janvier 2012
    Messages
    2 509
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 42
    Localisation : Maroc

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

    Informations forums :
    Inscription : Janvier 2012
    Messages : 2 509
    Par défaut
    Bonjour,

    Ou bien utilisez le mot clé global à l'intérieur de la fonction comme c'est montré dans l'exemple 3 de la doc, sans avoir a rajouter un autre paramètre à la fonction.

  6. #6
    Responsable Systèmes


    Homme Profil pro
    Gestion de parcs informatique
    Inscrit en
    Août 2011
    Messages
    18 256
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : Gestion de parcs informatique
    Secteur : High Tech - Matériel informatique

    Informations forums :
    Inscription : Août 2011
    Messages : 18 256
    Par défaut
    Je pense qu'il faut éviter les variables globales, les spécialistes PHP commenteront.
    Ma page sur developpez.com : http://chrtophe.developpez.com/ (avec mes articles)
    Mon article sur le P2V, mon article sur le cloud
    Consultez nos FAQ : Windows, Linux, Virtualisation

Discussions similaires

  1. Réponses: 4
    Dernier message: 02/06/2004, 16h35
  2. Transmission d'un objet crée dans une fonction
    Par EvilAngel dans le forum ASP
    Réponses: 2
    Dernier message: 10/05/2004, 20h19
  3. Utilisez MinimizeName() dans une fonction
    Par James_ dans le forum C++Builder
    Réponses: 7
    Dernier message: 07/05/2004, 18h05
  4. [Postgresql]Connecter à une autre base dans une fonction
    Par alex2205 dans le forum Requêtes
    Réponses: 2
    Dernier message: 05/05/2003, 11h30
  5. [Turbo Pascal] Allocation et désallocation de pointeurs dans une fonction
    Par neird dans le forum Turbo Pascal
    Réponses: 13
    Dernier message: 17/11/2002, 20h14

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