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 :

Bloc try and catch, requête préparée pour un select, les bonnes pratiques


Sujet :

PHP & Base de données

  1. #1
    Membre expert
    Avatar de Dendrite
    Femme Profil pro
    Développeuse informatique
    Inscrit en
    Juin 2008
    Messages
    2 129
    Détails du profil
    Informations personnelles :
    Sexe : Femme
    Âge : 58
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : Développeuse informatique
    Secteur : Administration - Collectivité locale

    Informations forums :
    Inscription : Juin 2008
    Messages : 2 129
    Points : 3 627
    Points
    3 627
    Billets dans le blog
    8
    Par défaut Bloc try and catch, requête préparée pour un select, les bonnes pratiques
    Bonsoir,

    Je profite d'une insomnie pour me faire un code type (bien sûr, il s'insèrera à terme dans une méthode objet).
    Toutes les questions que je me pose (elles sont nombreuses) sont dans les commentaires du code.
    Je suis impatiente d'avoir votre expertise sur la question...
    Merci d'avance

    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
    39
    40
    41
    42
    43
    44
    45
    46
    47
    48
    49
    50
    51
    52
    53
    54
    55
    56
    57
    58
    59
    60
    61
    <?php
    function selectFruits($dbh,$calories,$couleur){
    	//J'ai toujours besoin de savoir si la requête retourne au moins un tuple
    	$sql0='SELECT count(id)
    	FROM fruit
    	WHERE calories < :calories 
    	AND couleur = :couleur';
     
    	//requête préparée dès le comptage
    	$sth = $dbh->prepare($sql0, array(PDO::ATTR_CURSOR => PDO::CURSOR_FWDONLY));//suis pas sûre que c ce qu'il faut mettre ds le 2nd paramètre ici
    	if($sth->execute(array(':calories' => $calories, ':couleur' => $couleur))){
    		$res = $dbh->query($sql0);
    		if ($res->fetchColumn() > 0) { 
    			$res=NULL;
    			$sql = 'SELECT nom, couleur, calories
    			FROM fruit
    			WHERE calories < :calories AND couleur = :couleur';
     
    			//ici peut-on se passer des bind_param qui seraient redondants ?
    			/*$stmt=$dbh->prepare($sql);
    			$stmt->bindParam(':calories', $calories);
    			$stmt->bindParam(':couleur', $couleur);
    			if($stmt->execute(array(':calories' => $calories, ':couleur' => $couleur))){
    			*/
    			$data=array();
    			$stmt = $dbh->prepare($sql));
    			while ($row = $stmt->fetch(PDO::FETCH_ASSOC)){
    				array_push($data,$row);
    			}
    			return $data;
    		}
    		else{
    			return 0;
    		}
    	}
    	else{
    		return false;//en espérant que le bloc try & catch gère le msg d'erreur sql 
    	}
    }
    //peut-on mettre ainsi un bloc try & catch dans la page appelante, et se passer du bloc dans les méthodes ?
    //avec la portabilité des variables, ici externalisées de la fonction, j'ai des gros doutes...
    try {
    	$dbh = new PDO('mysql:host=localhost;dbname=test', $user, $pass);
    	$dbh->setAttribute(PDO::ATTR_ERRMODE, PDO::ERRMODE_EXCEPTION);
    	$data=selectFruits($dbh,130,'jaune');
     
    	$dbh = null;
     
    	if(is_array($data)){
    		echo '<pre>';
    		print_r($data);
    		echo '</pre>';
    	}
    	elseif($data==0){
    		echo 'Aucun fruit avec ces critères';
    	}
    }
    catch (PDOException $e) {
    	echo $e->getMessage() . "<br/>";
    }
    ?>
    PDO, une soupe et au lit !
    Partir de la fin est un bon moyen de retrouver son chemin. Bibi - 2020

  2. #2
    Membre expert
    Avatar de Spartacusply
    Homme Profil pro
    Développeur Web
    Inscrit en
    Mai 2011
    Messages
    1 723
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Loire Atlantique (Pays de la Loire)

    Informations professionnelles :
    Activité : Développeur Web
    Secteur : High Tech - Multimédia et Internet

    Informations forums :
    Inscription : Mai 2011
    Messages : 1 723
    Points : 3 274
    Points
    3 274
    Par défaut
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
     
    if($sth->execute(array(':calories' => $calories, ':couleur' => $couleur))){
    $res = $dbh->query($sql0);
    Y'a une erreur là, tu fais une query sur une requête préparée ? Qui plus est tu fais l'execute juste avant (qui est ce qu'il faut faire), je vois pas d'où tu veux en venir avec ton test à cet endroit là.
    Un message utile vous a aidé ? N'oubliez pas le

    www.simplifions.fr - Simplifier vos comptes entre amis !

  3. #3
    Candidat au Club
    Homme Profil pro
    Responsable de service informatique
    Inscrit en
    Mai 2013
    Messages
    6
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 49
    Localisation : France, Ille et Vilaine (Bretagne)

    Informations professionnelles :
    Activité : Responsable de service informatique

    Informations forums :
    Inscription : Mai 2013
    Messages : 6
    Points : 3
    Points
    3
    Par défaut
    Salut,

    Oui tu as un problème dans ta fonction :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    if($sth->execute(array(':calories' => $calories, ':couleur' => $couleur))){
    Là tu viens d'exécuter la requête, OK

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    $res = $dbh->query($sql0);
    Là tu réexécute la requête, sauf que ->query ne marche pas avec une requête préparée, et en plus c'est inutile

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    $stmt = $dbh->prepare($sql));
    Et là tu prépare une autre requête, mais tu ne l'exécute pas

    Tu pourrais juste faire ça à mon avis :

    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
     
    function selectFruits($dbh,$calories,$couleur){
        //J'ai toujours besoin de savoir si la requête retourne au moins un tuple
        $sql0='SELECT count(id)
        FROM fruit
        WHERE calories < :calories 
        AND couleur = :couleur';
     
        //requête préparée dès le comptage
        $sth = $dbh->prepare($sql0, array(PDO::ATTR_CURSOR => PDO::CURSOR_FWDONLY));//suis pas sûre que c ce qu'il faut mettre ds le 2nd paramètre ici
     
    $res = $sth->execute(array(':calories' => $calories, ':couleur' => $couleur));
     
    if ($res->fetchColumn() > 0) { 
       $res=NULL;
       $sql = 'SELECT nom, couleur, calories
       FROM fruit
       WHERE calories < :calories AND couleur = :couleur';
     
       $stmt=$dbh->prepare($sql);
       $stmt->bindParam(':calories', $calories);
       $stmt->bindParam(':couleur', $couleur);
     
    $data=array();
       $stmt = $dbh->prepare($sql));
       while ($row = $stmt->fetch(PDO::FETCH_ASSOC)){
        array_push($data,$row);
       }
       return $data;
      }
      else{
       return 0;
      }
     
        else{
      return false;//en espérant que le bloc try & catch gère le msg d'erreur sql 
        }
    }

  4. #4
    Modérateur
    Avatar de sabotage
    Homme Profil pro
    Inscrit en
    Juillet 2005
    Messages
    29 208
    Détails du profil
    Informations personnelles :
    Sexe : Homme

    Informations forums :
    Inscription : Juillet 2005
    Messages : 29 208
    Points : 44 155
    Points
    44 155
    Par défaut
    Je ne vois pas l'interêt de faire un COUNT d'abord.

    Egalement tu as la méthode fetch_all si tu veux tous les résultats :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    while ($row = $stmt->fetch(PDO::FETCH_ASSOC)){
        array_push($data,$row);
       }
    =>
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    $row = $stmt->fetch_all(PDO::FETCH_ASSOC)
    N'oubliez pas de consulter les FAQ PHP et les cours et tutoriels PHP

Discussions similaires

  1. Réponses: 1
    Dernier message: 28/09/2010, 12h34
  2. [AC-2003] Critère requête VraiFaux() pour sélectionner tous les enregistrements
    Par lio33 dans le forum Requêtes et SQL.
    Réponses: 4
    Dernier message: 05/10/2009, 09h39
  3. [Débutant] Instruction try and catch
    Par Asmlibero dans le forum MATLAB
    Réponses: 2
    Dernier message: 19/01/2009, 10h37
  4. [PDO] une requête préparée pour un insert avec jointure?
    Par seïna dans le forum PHP & Base de données
    Réponses: 8
    Dernier message: 15/08/2008, 00h34

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