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 :

transmission de l'objet retourné par mysqli_connect [MySQL]


Sujet :

PHP & Base de données

  1. #1
    Expert confirmé
    Avatar de laurentSc
    Homme Profil pro
    Webmaster débutant perpétuel !
    Inscrit en
    Octobre 2006
    Messages
    10 363
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 60
    Localisation : France, Isère (Rhône Alpes)

    Informations professionnelles :
    Activité : Webmaster débutant perpétuel !
    Secteur : Industrie

    Informations forums :
    Inscription : Octobre 2006
    Messages : 10 363
    Points : 5 733
    Points
    5 733
    Billets dans le blog
    1
    Par défaut transmission de l'objet retourné par mysqli_connect
    Bonjour,

    pour effectuer une requête mysqli (mysqli_query), il faut passer en paramètre l'objet retourné par la fonction de connexion. Comme cette connexion est effectuée dans un fichier séparé (connect_mysql.php), pour transmettre cet objet, j'ai choisi de le mettre dans une variable de session :
    connect_mysql.php :
    Code php : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    <?php
    session_start();
    function connect_mysql() {
    ...
    	$link=mysqli_connect('localhost','root','',$dbase); // wampserver
    	if (isset($link)) {
    		echo "connexion OK<br/>";
    		$_SESSION['link']=$link;
    	}
    	return($link);
    }
    ?>
    et dans un autre fichier :
    Code php : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    <?php
    session_start();
    $link=$_SESSION['link'];
    echo "authenticate:link:".$link->info."<br/>";
    et cela affiche :
    connexion OK
    ...
    authenticate:link:
    donc pas de $link ; il faut faire autrement pour transmettre cette variable ?
    Il vaut mieux viser la perfection et la manquer que viser l'imperfection et l'atteindre. - Bertrand Russell

    Si la discussion est résolue, merci de cliquer sur le bouton

  2. #2
    Rédacteur

    Avatar de Bovino
    Homme Profil pro
    Développeur Web
    Inscrit en
    Juin 2008
    Messages
    23 647
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 53
    Localisation : France, Gironde (Aquitaine)

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

    Informations forums :
    Inscription : Juin 2008
    Messages : 23 647
    Points : 91 418
    Points
    91 418
    Billets dans le blog
    20
    Par défaut
    En variable de session...

    Enfin bref...
    J'imagine qu'avant de poster, tu t'es bien entendu demandé ce qu'est supposé contenir $mysqli->info quand tu n'as encore fait aucune requête ?
    Et au passage, ça te semble logique et cohérent d'initialiser une connexion en mode procédural et de continuer en objet ?
    Pas de question technique par MP !
    Tout le monde peut participer à developpez.com, vous avez une idée, contactez-moi !
    Mes formations video2brain : La formation complète sur JavaScriptJavaScript et le DOM par la pratiquePHP 5 et MySQL : les fondamentaux
    Mon livre sur jQuery
    Module Firefox / Chrome d'intégration de JSFiddle et CodePen sur le forum

  3. #3
    Rédacteur

    Avatar de Bovino
    Homme Profil pro
    Développeur Web
    Inscrit en
    Juin 2008
    Messages
    23 647
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 53
    Localisation : France, Gironde (Aquitaine)

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

    Informations forums :
    Inscription : Juin 2008
    Messages : 23 647
    Points : 91 418
    Points
    91 418
    Billets dans le blog
    20
    Par défaut
    Ah, au fait, pour anticiper les prochaines questions : demandes-toi aussi ce que devient une connexion une fois que le script PHP a fini son exécution. Dit autrement, penses-tu réellement que la connexion peut rester ouverte d'une page à l'autre ?
    Non pas que ce ne soit pas possible, mais ça ne l'est pas de la façon dont tu le fais et c'est, à ma connaissance, assez fortement déconseillé.
    Pas de question technique par MP !
    Tout le monde peut participer à developpez.com, vous avez une idée, contactez-moi !
    Mes formations video2brain : La formation complète sur JavaScriptJavaScript et le DOM par la pratiquePHP 5 et MySQL : les fondamentaux
    Mon livre sur jQuery
    Module Firefox / Chrome d'intégration de JSFiddle et CodePen sur le forum

  4. #4
    Expert confirmé
    Avatar de laurentSc
    Homme Profil pro
    Webmaster débutant perpétuel !
    Inscrit en
    Octobre 2006
    Messages
    10 363
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 60
    Localisation : France, Isère (Rhône Alpes)

    Informations professionnelles :
    Activité : Webmaster débutant perpétuel !
    Secteur : Industrie

    Informations forums :
    Inscription : Octobre 2006
    Messages : 10 363
    Points : 5 733
    Points
    5 733
    Billets dans le blog
    1
    Par défaut
    Une fois de plus (je sais que c'est ce que tu penses), j'ai fait n'importe quoi.

    Parler de variable objet alors que l'on est en procédural, je te l'accorde, c'est pas très logique ; néanmoins, selon la doc , la fonction mysqli_connect retourne un objet, même si on est en procédural...

    Le $link->info avant une requête, selon le var_dump semble être NULL.

    Enfin, OK (je viens de le découvrir après t'avoir lu), en dehors des connexions persistantes, les connexions aux bdd se referment à la fin de l'exécution du script. Par contre, vu la conception de ce code (qui n'est pas de moi ; je le reprends), la page où est faite la connexion reste tout le temps ouverte vu que les autres fichiers sont "includés" ; et d'ailleurs, pas besoin de transmettre $link car ils la connaissent (je viens de le vérifier par un var_dump). Par contre, dans une des pages "includées", le code
    Code php : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
     
    		var_dump($link);
     
    		$query = "SELECT * FROM users";
    		$result = mysqli_query($query,$link) or die ("Impossible d'exécuter la requete sur la table users...");
    affiche
    object(mysqli)[2]
    public 'affected_rows' => null
    public 'client_info' => null
    public 'client_version' => null
    public 'connect_errno' => null
    public 'connect_error' => null
    public 'errno' => null
    public 'error' => null
    public 'error_list' => null
    public 'field_count' => null
    public 'host_info' => null
    public 'info' => null
    public 'insert_id' => null
    public 'server_info' => null
    public 'server_version' => null
    public 'stat' => null
    public 'sqlstate' => null
    public 'protocol_version' => null
    public 'thread_id' => null
    public 'warning_count' => null

    Impossible d'exécuter la requete sur la table users...
    alors que la table "users" existe bien dans la bdd qui vient d'être ouverte. Quel est donc le souci ?
    Il vaut mieux viser la perfection et la manquer que viser l'imperfection et l'atteindre. - Bertrand Russell

    Si la discussion est résolue, merci de cliquer sur le bouton

  5. #5
    Expert confirmé
    Avatar de laurentSc
    Homme Profil pro
    Webmaster débutant perpétuel !
    Inscrit en
    Octobre 2006
    Messages
    10 363
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 60
    Localisation : France, Isère (Rhône Alpes)

    Informations professionnelles :
    Activité : Webmaster débutant perpétuel !
    Secteur : Industrie

    Informations forums :
    Inscription : Octobre 2006
    Messages : 10 363
    Points : 5 733
    Points
    5 733
    Billets dans le blog
    1
    Par défaut
    Après avoir fait une longue pause, je l'ai trouvé : j'avais inversé $link et $query !
    Il vaut mieux viser la perfection et la manquer que viser l'imperfection et l'atteindre. - Bertrand Russell

    Si la discussion est résolue, merci de cliquer sur le bouton

  6. #6
    Rédacteur

    Avatar de Bovino
    Homme Profil pro
    Développeur Web
    Inscrit en
    Juin 2008
    Messages
    23 647
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 53
    Localisation : France, Gironde (Aquitaine)

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

    Informations forums :
    Inscription : Juin 2008
    Messages : 23 647
    Points : 91 418
    Points
    91 418
    Billets dans le blog
    20
    Par défaut
    Tiens, ça me rappelle étrangement une précédente discussion...
    Citation Envoyé par Bovino Voir le message
    ou alors, il n'a pas ce nom là (après tout, ce ne serait pas le première fois que tu nous ferais ce coup-là...).


    Citation Envoyé par laurentSc
    je sais que c'est ce que tu penses
    Ce que j'en pense, c'est que ce n'est en rien le rôle du forum que de faire quasi systématiquement ce type de débogage pour toi.
    Pas de question technique par MP !
    Tout le monde peut participer à developpez.com, vous avez une idée, contactez-moi !
    Mes formations video2brain : La formation complète sur JavaScriptJavaScript et le DOM par la pratiquePHP 5 et MySQL : les fondamentaux
    Mon livre sur jQuery
    Module Firefox / Chrome d'intégration de JSFiddle et CodePen sur le forum

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

Discussions similaires

  1. Réponses: 2
    Dernier message: 03/05/2012, 20h35
  2. Récupérer un Objet retourné par Axis 2
    Par Azaxx dans le forum Services Web
    Réponses: 1
    Dernier message: 21/03/2012, 01h24
  3. [MySQL] Tableau d'objets retourné par méthode de select multiple MySQL
    Par VisualagePacMan dans le forum PHP & Base de données
    Réponses: 1
    Dernier message: 19/12/2011, 10h18
  4. objet retourné par une méthode
    Par wafiwafi dans le forum Général Java
    Réponses: 4
    Dernier message: 17/08/2011, 23h37
  5. Réponses: 9
    Dernier message: 21/11/2008, 22h59

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