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 :

Récupérer toutes les données d'une table


Sujet :

PHP & Base de données

  1. #1
    Membre éprouvé
    Homme Profil pro
    Ingénieur en électrotechnique retraité
    Inscrit en
    Décembre 2008
    Messages
    1 718
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 73
    Localisation : France, Bas Rhin (Alsace)

    Informations professionnelles :
    Activité : Ingénieur en électrotechnique retraité

    Informations forums :
    Inscription : Décembre 2008
    Messages : 1 718
    Par défaut Récupérer toutes les données d'une table
    Bonjour,
    J'ai l'habitude de récupérer des données avec des requêtes préparées et des paramètres mais je n'arrive pas à récupérer toutes les données d'une table sans paramètres. J'ai épluché la doc sur PDO::query() et PDO::exec() mais je n'y arrive pas. Ma table ne devrait contenir que 4 ou 5 lignes maxi. Je voudrais un truc comme avec fetchAll().
    Ici qui peut le plus ne peut pas le moins!!!!
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    function getRequests(){
    	$db = dbConnect();
     
    	$sql = <<<SQL
    SELECT * FROM dat_subs_requests
    SQL;
    	//$r = $db->query($sql);
    	//var_dump($r);
    	//return $db->exec($sql);
    }

  2. #2
    Expert confirmé
    Avatar de Séb.
    Profil pro
    Inscrit en
    Mars 2005
    Messages
    5 319
    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 319
    Billets dans le blog
    17
    Par défaut
    Ceci devrait suffire :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    function getRequests()
    {
    	$db = dbConnect();
     
    	$sql = 'SELECT * FROM dat_subs_requests';
    	$r = $db->query($sql);
            $data = $r->fetchAll();
            print_r($data);
    }

  3. #3
    Membre éprouvé
    Homme Profil pro
    Ingénieur en électrotechnique retraité
    Inscrit en
    Décembre 2008
    Messages
    1 718
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 73
    Localisation : France, Bas Rhin (Alsace)

    Informations professionnelles :
    Activité : Ingénieur en électrotechnique retraité

    Informations forums :
    Inscription : Décembre 2008
    Messages : 1 718
    Par défaut
    Merci. C'est ce que je cherchais. tout est OK.

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

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

    Informations forums :
    Inscription : Octobre 2006
    Messages : 10 493
    Billets dans le blog
    1
    Par défaut
    Bonsoir,

    je ne saurais pas le justifier mais les spécialistes déconseillent les requêtes select * from nom_table et préfèrent nommer les colonnes : select col1, col2, etc from nom_table .

    Citation Envoyé par escartefigue Voir le message
    Note : select * est à proscrire, il ne faut utiliser que les colonnes utiles au traitement.

  5. #5
    Expert confirmé
    Avatar de Séb.
    Profil pro
    Inscrit en
    Mars 2005
    Messages
    5 319
    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 319
    Billets dans le blog
    17
    Par défaut
    Quand toutes les colonnes sont utiles au traitement (et qu'on ne compte pas en ajouter), alors SELECT * est envisageable (même si perso je préfère éviter, question de lisibilité).

    SELECT * est aussi pratique en phase d'exploration de la data.

    Dans les autres cas c'est vrai qu'on rapatrie toute la data pour rien, et que ça peut peser sur la mémoire et ralentir les traitements.

  6. #6
    Modérateur
    Avatar de escartefigue
    Homme Profil pro
    bourreau
    Inscrit en
    Mars 2010
    Messages
    10 599
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Loir et Cher (Centre)

    Informations professionnelles :
    Activité : bourreau
    Secteur : Finance

    Informations forums :
    Inscription : Mars 2010
    Messages : 10 599
    Billets dans le blog
    10
    Par défaut
    Attention : SELECT * n'est pas seulement à proscrire parce qu'il ramène le plus souvent des colonnes dont on n'a pas besoin au détriment des performances et de la charge réseau, mais aussi parce que :
    • si on a des jointures, toutes les colonnes de jointure sont récupérées plusieurs fois
    • et surtout, si la table ou la vue change (ajout ou suppression de colonnes), le résultat de la requête change !


    SELECT * ne doit être utilisé que pour des requêtes à la volée, pas pour des requêtes encapsulées dans des traitements
    D'ailleurs il n'est pas rare que SELECT * soit interdit en entreprises pour ces raisons.

  7. #7
    Membre éprouvé
    Homme Profil pro
    Ingénieur en électrotechnique retraité
    Inscrit en
    Décembre 2008
    Messages
    1 718
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 73
    Localisation : France, Bas Rhin (Alsace)

    Informations professionnelles :
    Activité : Ingénieur en électrotechnique retraité

    Informations forums :
    Inscription : Décembre 2008
    Messages : 1 718
    Par défaut
    Merci pour ces conseils, j'ai listé les colonnes même si dans le cas présent je les utilise toutes.

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

Discussions similaires

  1. Comment ne pas récupérer toutes les informations d'une table jointe ?
    Par Daïmanu dans le forum Persistance des données
    Réponses: 4
    Dernier message: 08/10/2017, 17h46
  2. [AJAX] Récupérer toutes les données d'une BDD
    Par OurysBack dans le forum AJAX
    Réponses: 0
    Dernier message: 12/11/2014, 11h28
  3. [XL-2007] Récupérer toutes les données d'une ligne liées a un indice
    Par cwamm dans le forum Macros et VBA Excel
    Réponses: 2
    Dernier message: 03/10/2014, 17h26
  4. extraire toutes les données d'une table (coté serveur)
    Par stoner2008 dans le forum Servlets/JSP
    Réponses: 0
    Dernier message: 13/06/2014, 12h40
  5. Récupérer toutes les données en une fois depuis la base.
    Par zuzuu dans le forum Persistance des données
    Réponses: 3
    Dernier message: 10/03/2009, 11h41

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