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 :

Requête SELECT sur plusieurs champs [Fait] [PDO]


Sujet :

PHP & Base de données

  1. #1
    Candidat au Club
    Profil pro
    Inscrit en
    Mai 2007
    Messages
    3
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Mai 2007
    Messages : 3
    Points : 3
    Points
    3
    Par défaut Requête SELECT sur plusieurs champs
    Bonjour à tous,

    Je viens de rencontrer un problème avec PDO et mes connaissances étant un peu limitée dans cet outil j'espère trouvé ici un peu d'aide.

    Mon problème est le suivant:

    Lorsque j'exécute une requête SELECT où je demande qu'un seul champ, il n'y a aucun problème. Le retour est bon.

    ex:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    	public function login($login, $password) {
     
    			$sql = "SELECT login FROM user WHERE login = '$login' and password = SHA1('$password')";
    			return $this->db->query($sql);
    	}

    En revanche, dès lors que je demande plusieurs champs dans ma requête SQL, le navigateur galère: il y a marqué dans la barre d'état: en attente de localhost (au passage j'utilise la dernière version de XAMPPLITE).

    Puis ça se termine au bout d'une ou 2 secondes avec un message de "Connexion interrompue" (La connexion avec le serveur a été réinitialisée pendant le chargement de la page).

    Ex:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    	public function login($login, $password) {
     
    			$sql = "SELECT * FROM user WHERE login = '$login' and password = SHA1('$password')";
    			return $this->db->query($sql);
    	}
    J'ai essayé avec la méthode classique, mysql_connect etc... et dans ce cas tout marche impeccable.


    Voila, vous savez tout, j'espère que vous pourrez m'aider car entre PDO et moi notre relation démarre plutôt mal .

    D'avance merci,
    (Je vous pris de m'excuser si il existe déjà un topic à ce sujet, il m'a échappé.)


    Mathieu.

    ps: ma class connexion si besoin

    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
    class Connexion {
     
       public $dsn;
       public $db;
       public $username;
       public $password;
     
       public function __construct() {	
     
    	  $this->username = root;
    	  $this->password = '';
     
    	  $this->dsn = 'mysql:host=localhost;dbname=w';  
    	  self::connect();   
       }
     
       public function connect() {
     
          try {
     
    	     $this->db = new PDO($this->dsn, $this->username, $this->password);
    	     $this->db->setAttribute(PDO::ATTR_EMULATE_PREPARES, TRUE);
    	     $this->db->setAttribute(PDO::ATTR_ERRMODE, PDO::ERRMODE_EXCEPTION); // les erreurs lanceront des exceptions
    		 $this->db->setAttribute(PDO::ATTR_CASE, PDO::CASE_LOWER); // les noms de champs seront en caractères minuscules
     
          } catch (PDOException $e) {
    	     echo 'Erreur: ' . $e->getMessage();
    	  }
     
       }
     
    	public function login($login, $password) {
     
    			$sql = "SELECT * FROM user WHERE login = '$login' and password = SHA1('$password')";
    			return $this->db->query($sql);
    	}
     
    }

  2. #2
    Expert éminent sénior
    Avatar de mathieu
    Profil pro
    Inscrit en
    Juin 2003
    Messages
    10 234
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Juin 2003
    Messages : 10 234
    Points : 15 531
    Points
    15 531
    Par défaut
    pour passer des valeurs à une requête, utilise plutôt des requêtes paramétrées comme dans les exemples de cette page :
    http://php.net/pdostatement.execute

  3. #3
    Candidat au Club
    Profil pro
    Inscrit en
    Mai 2007
    Messages
    3
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Mai 2007
    Messages : 3
    Points : 3
    Points
    3
    Par défaut
    Merci beaucoup de ton conseil je vais essayer de faire ça à l'avenir.
    Au sujet de mon problème, j'avais essayé avec d'autres techniques d'exécutions et le résultat était le même.. :/


    EDIT:

    Problème "résolu", c'était un soucis avec XAMPP, avec un autre logiciel pour apache et mySQL tout se passe bien.

    Merci à tous ceux qui ont pris la peine de lire mon message.

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

Discussions similaires

  1. Requête faite sur plusieurs champs provenant de plusieurs tables
    Par olivier777 dans le forum Requêtes et SQL.
    Réponses: 8
    Dernier message: 14/05/2008, 17h34
  2. Liste de selection sur plusieurs champs
    Par Corran Horn dans le forum Langage
    Réponses: 3
    Dernier message: 09/04/2008, 14h44
  3. Requête : distinct sur plusieurs champs
    Par bractar dans le forum Langage SQL
    Réponses: 13
    Dernier message: 08/06/2007, 19h54
  4. requête condition sur plusieurs champs
    Par grinder59 dans le forum Langage SQL
    Réponses: 9
    Dernier message: 23/02/2007, 13h52
  5. requête max sur plusieurs champs
    Par logica dans le forum Access
    Réponses: 3
    Dernier message: 28/03/2006, 16h31

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