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 :

PDO erreur de connexion [MySQL]


Sujet :

PHP & Base de données

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre éprouvé Avatar de lodan
    Profil pro
    Inscrit en
    Juin 2006
    Messages
    2 064
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Juin 2006
    Messages : 2 064
    Par défaut PDO erreur de connexion
    Bonjour,

    Mon environnement est un NAS Synology avec :
    - Apache/2.2.34 (Unix)
    - PHP Version 5.6.40
    - mysqlnd 5.0.11

    Je souhaite me connecter à la base de données mais n'y arrive pas.

    J'ai donc fait un script très court :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    <?php
    try {
        $dbh = new PDO('mysql:host=localhost;dbname=agora', 'user', 'password');
        foreach($dbh->query('SELECT * from FOO') as $row) {
            print_r($row);
        }
        $dbh = null;
    } catch (PDOException $e) {
        print "Erreur !: " . $e->getMessage() . "<br/>";
        die();
    }
    ?>
    Et j'ai l'erreur suivante :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    Erreur !: SQLSTATE[HY000] [2002] No such file or directory
    Ma base de données existe bien puisque je la vois depuis phpMyAdmin avec le même login/password.
    Le serveur base de donnée affiché dans phpMyAdmin est
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    Serveur : MariaDB 10 (Localhost via UNIX socket)
    Merci pour votre retour d'expérience sur une connexion via PDO, c'est une 1ère pour moi.

  2. #2
    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 : 40
    Localisation : France

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

    Informations forums :
    Inscription : Avril 2007
    Messages : 8 633
    Par défaut
    Question bête : est-ce que ça fonctionne si tu utilise mysqli ?
    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]

  3. #3
    Membre éprouvé Avatar de lodan
    Profil pro
    Inscrit en
    Juin 2006
    Messages
    2 064
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Juin 2006
    Messages : 2 064
    Par défaut
    Oh que ce n'est pas bête. J'ai donc fait ceci :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    $mysqli = new mysqli("localhost", "user", "password", "agora");
    if ($mysqli->connect_errno) {
        echo "Echec lors de la connexion à MySQL : (" . $mysqli->connect_errno . ") " . $mysqli->connect_error;
    }
    echo $mysqli->host_info . "\n";
     
    $mysqli = new mysqli("127.0.0.1", "user", "password", "database", 3306);
    if ($mysqli->connect_errno) {
        echo "Echec lors de la connexion à MySQL : (" . $mysqli->connect_errno . ") " . $mysqli->connect_error;
    }
    et le retour est
    Warning: mysqli::mysqli(): (HY000/2002): No such file or directory in

  4. #4
    Membre éprouvé Avatar de lodan
    Profil pro
    Inscrit en
    Juin 2006
    Messages
    2 064
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Juin 2006
    Messages : 2 064
    Par défaut
    Bonjour,

    J'ai modifié mon script pour le host :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    $mysqli = new mysqli("localhost", "user", "password", "agora");
    if ($mysqli->connect_errno) {
        echo "Echec lors de la connexion à MySQL : (" . $mysqli->connect_errno . ") " . $mysqli->connect_error;
    }
    echo $mysqli->host_info . "\n";
     
    $mysqli = new mysqli("127.0.0.1", "user", "password", "database", 3306);
    if ($mysqli->connect_errno) {
        echo "Echec lors de la connexion à MySQL : (" . $mysqli->connect_errno . ") " . $mysqli->connect_error;
    Et l'erreur qui s'affiche maintenant est :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    MySQL : (2002) Connection refused

  5. #5
    Invité
    Invité(e)
    Par défaut
    Bonjour,

    1- Euhhh... Je ne pense pas que Celira te proposais d'utiliser mysqli_, mais juste de tester la connexion avec.

    Le mieux est quand même d'utiliser PDO.

    A LIRE :


    2- Vérifie aussi tes paramètres de connexion à la BDD.
    En local, souvent, "user", "password" vaut "root", "".

  6. #6
    Membre éprouvé Avatar de lodan
    Profil pro
    Inscrit en
    Juin 2006
    Messages
    2 064
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Juin 2006
    Messages : 2 064
    Par défaut
    Citation Envoyé par jreaux62 Voir le message
    Bonjour,

    1- Euhhh... Je ne pense pas que Celira te proposais d'utiliser mysqli_, mais juste de tester la connexion avec.

    Le mieux est quand même d'utiliser PDO.

    A LIRE :


    2- Vérifie aussi tes paramètres de connexion à la BDD.
    En local, souvent, "user", "password" vaut "root", "".
    Merci le mysqli est juste pour le test, oui j'utiliserai que le PDO.

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    try {
        $dbh = new PDO('mysql:host=localhost:/run/mysqld/mysqld10.sock;dbname=agora', 'root', 'root');
        foreach($dbh->query('SELECT * from FOO') as $row) {
            print_r($row);
        }
        $dbh = null;
    } catch (PDOException $e) {
        print "Erreur !: " . $e->getMessage() . "<br/>";
        die();
    Je garde cette erreur
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    Erreur !: SQLSTATE[HY000] [2002] Connection refused
    Les identifiants fonctionnent avec PHPMyAdmin.

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

Discussions similaires

  1. [PDO] Connexion avec PDO [Erreur : could not find driver]
    Par Berlo56 dans le forum PHP & Base de données
    Réponses: 7
    Dernier message: 22/04/2014, 10h41
  2. [PDO] PDO Erreur de connexion ": SQLSTATE[HY000] [2002]"
    Par baffreux dans le forum PHP & Base de données
    Réponses: 3
    Dernier message: 01/04/2014, 16h40
  3. [PDO] erreur de connexion PDO
    Par Souri84 dans le forum PHP & Base de données
    Réponses: 3
    Dernier message: 22/04/2011, 13h57
  4. [PDO] Erreur HY000 lors d'un New PDO pour une connexion sur Mysql
    Par siciliano21 dans le forum PHP & Base de données
    Réponses: 4
    Dernier message: 22/07/2009, 15h19

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