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 :

Demande de simplification de SELECT [MySQL]


Sujet :

PHP & Base de données

  1. #1
    Invité
    Invité(e)
    Par défaut Demande de simplification de SELECT
    Bonjour,
    Je réalise un SELECT qui marche bien ,cependant cette requête, s'adresse obligatoirement a un seul enregistrement qui en plus EXISTE !
    Alors je me demande, si il existe une syntaxe plus simple que ce while
    Mille mercis 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
     
              $requete="SELECT * FROM  `w_dvd` WHERE `DvdDate`=:La1 and `DvdTitre`=:La2 and `DvdTaille`=:La3 and `DvdOu`=:La4 " ;
              $result = $bdd->prepare($requete);
              $result->bindParam(':La1', $DvdDate, PDO::PARAM_STR);
              $result->bindParam(':La2', $DvdTitre, PDO::PARAM_STR);
              $result->bindParam(':La3', $DvdTaille, PDO::PARAM_STR);
              $result->bindParam(':La4', $DvdOu, PDO::PARAM_STR);
              $result->execute();
              while ($row = $result->fetch())
               {
                $DvdMajx1= $row['DvdMaj1'];
                $DvdMajx2= $row['DvdMaj2'];
                $DvdMajx3= $row['DvdMaj3'];
               }

  2. #2
    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
    Tu peux enlever le while.
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    $row = $result->fetch();
    $DvdMajx1= $row['DvdMaj1'];
    $DvdMajx2= $row['DvdMaj2'];
    $DvdMajx3= $row['DvdMaj3'];
    N'oubliez pas de consulter les FAQ PHP et les cours et tutoriels PHP

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

    J'ai rien compris...

  4. #4
    Modérateur

    Avatar de MaitrePylos
    Homme Profil pro
    DBA
    Inscrit en
    Juin 2005
    Messages
    5 496
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 51
    Localisation : Belgique

    Informations professionnelles :
    Activité : DBA
    Secteur : Service public

    Informations forums :
    Inscription : Juin 2005
    Messages : 5 496
    Points : 12 596
    Points
    12 596
    Par défaut
    Salut,

    Tu peux aussi optimiser et ne prendre que ce que tu as besoin dans la db :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
     
     
    $requete="SELECT DvdMaj1,DvdMaj2,DvdMaj3 FROM  `w_dvd` WHERE `DvdDate`=:La1 and `DvdTitre`=:La2 and `DvdTaille`=:La3 and `DvdOu`=:La4 " ;

  5. #5
    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 : 39
    Localisation : France

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

    Informations forums :
    Inscription : Avril 2007
    Messages : 8 633
    Points : 16 372
    Points
    16 372
    Par défaut
    Et éventuellement, te passer des fonctions bindParam et passer les valeurs directement à la fonction execute.
    Ce qui donne, en reprenant les suggestions précédentes :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    $requete = "SELECT DvdMaj1, DvdMaj2, DvdMaj3 FROM  `w_dvd` WHERE `DvdDate`=:La1 and `DvdTitre`=:La2 and `DvdTaille`=:La3 and `DvdOu`=:La4 ";
    $result = $bdd->prepare($requete);
    $result->execute(array(
        ':La1' => $DvdDate,
        ':La2' => $DvdTitre,
        ':La3' => $DvdTaille,
        ':La4' => $DvdOu
    ));
    $row = $result->fetch();
    $DvdMajx1 = $row['DvdMaj1'];
    $DvdMajx2 = $row['DvdMaj2'];
    $DvdMajx3 = $row['DvdMaj3'];
    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]

  6. #6
    Invité
    Invité(e)
    Par défaut
    Trois réponses et en plus de trois Amis (même ceux qui se souviennent de FoxLeRenard
    C'est trop beau, je vais piocher et adopter une concaténation de vos avis mille mercis et à bientôt

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

Discussions similaires

  1. Réponses: 4
    Dernier message: 19/06/2014, 17h11
  2. un select case qui ne fait pas tout ce qu'on lui demande
    Par will Igetit dans le forum Excel
    Réponses: 1
    Dernier message: 17/12/2008, 21h18
  3. Simplification d'un select case
    Par portecd dans le forum VBA Access
    Réponses: 5
    Dernier message: 29/11/2007, 23h17
  4. Simplification d'un select case
    Par nellynew dans le forum Langage SQL
    Réponses: 3
    Dernier message: 21/06/2007, 08h57
  5. Réponses: 2
    Dernier message: 24/04/2007, 20h04

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