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 :

Problème de recupération des valeurs d'un select [MySQL]


Sujet :

PHP & Base de données

  1. #1
    Membre éprouvé
    Homme Profil pro
    Benevole
    Inscrit en
    Mai 2004
    Messages
    1 679
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Côte d'Ivoire

    Informations professionnelles :
    Activité : Benevole
    Secteur : Enseignement

    Informations forums :
    Inscription : Mai 2004
    Messages : 1 679
    Points : 954
    Points
    954
    Par défaut Problème de recupération des valeurs d'un select
    Bonsoir a tous

    J'ai besoin de récupérer les valeurs d'un select dans deux variables voici mon code je sais pas comment récupérer les valeurs de :id_ecole, libcourt_ec

    Code PHP : 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
     
    <?php
     
    include "connect.php";
     
    $matricule='1'; 
    $nom_info='USTCI';
     
    $query = 'select id_ecole, libcourt_ec from mon_ecole where id_ecole=? and libcourt_ec=?';
     
    $prep = $pdo->prepare($query);
     
    //Associer des valeurs aux place holders
    $prep->bindValue(1, $matricule, PDO::PARAM_INT);
    $prep->bindValue(2, $nom_info, PDO::PARAM_STR);
     
    //Compiler et exécuter la requête
    $prep->execute();
     
    //Récupérer toutes les données retournées
    $arrAll = $prep->fetchAll();
     
    //Clore la requête préparée
    $prep->closeCursor();
    $prep = NULL;
     
    ?>

    Merci de m'aider

  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
    Ta requête n'a pas de sens : tu demandes les valeurs de id_ecole et libcourt_ec quand id_ecole vaut $matricule et libcourt_ec vaut $nom_info.
    Au pire il n'y a pas de résultat, au mieux tu obtiens les valeurs que tu connais déjà : $matricule et $nom_info.
    N'oubliez pas de consulter les FAQ PHP et les cours et tutoriels PHP

  3. #3
    Membre éprouvé
    Homme Profil pro
    Benevole
    Inscrit en
    Mai 2004
    Messages
    1 679
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Côte d'Ivoire

    Informations professionnelles :
    Activité : Benevole
    Secteur : Enseignement

    Informations forums :
    Inscription : Mai 2004
    Messages : 1 679
    Points : 954
    Points
    954
    Par défaut
    ok la j'ai modifier en mettant bindParam et j'ai tenté d'afficher $arrAll
    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
     
    <?php
     
    include "connect.php";
     
    $matricule='1'; 
    $nom_info='USTCI';
     
    $query = 'select id_ecole, libcourt_ec from mon_ecole where id_ecole=? and libcourt_ec=?';
     
    $prep = $pdo->prepare($query);
     
    //Associer des valeurs aux place holders
    $prep->bindParam(1, $matricule, PDO::PARAM_INT);
    $prep->bindParam(2, $nom_info, PDO::PARAM_STR);
     
    //Compiler et exécuter la requête
    $prep->execute();
     
    //Récupérer toutes les données retournées
    $arrAll = $prep->fetchAll();
    echo $arrAll;
     
    //Clore la requête préparée
    $prep->closeCursor();
    $prep = NULL;
     
    ?>
    Mais j'ai l'erreur suivante à la ligne echo $arrAll;
    Notice: Array to string conversion in...

  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
    ça ne change pas le fait que ta requête n'a pas de sens.
    Que cherches-tu as obtenir ?
    N'oubliez pas de consulter les FAQ PHP et les cours et tutoriels PHP

  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
    Citation Envoyé par devalender Voir le message
    j'ai l'erreur suivante à la ligne echo $arrAll;
    Pour débuguer une variable, mieux vaut utiliser var_​dump qui va t'afficher tout ce qu'il peut quelque soit le contenu de la variable (y compris dans le cas où la variable n'est pas renseignée) :
    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
    Membre éprouvé
    Homme Profil pro
    Benevole
    Inscrit en
    Mai 2004
    Messages
    1 679
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Côte d'Ivoire

    Informations professionnelles :
    Activité : Benevole
    Secteur : Enseignement

    Informations forums :
    Inscription : Mai 2004
    Messages : 1 679
    Points : 954
    Points
    954
    Par défaut
    Bonjour

    Toutes mes excuses pour le retard dans mon post.
    En effet je veux juste vérifier que id_ecole, libcourt_ec avec les valeurs
    id_ecole='1';
    libcourt_ec='USTCI'
    existe bien dans ma base. je passe donc par des variables (juste pour les tests. en effet ces deux variables viennent d'un formulaire !). d’où
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
     
    $matricule='1'; 
    $nom_info='USTCI';
    pour simuler les valeurs venant d'un formulaire.

    Ensuite je veux pouvoir récupérer les valeurs de id_ecole, libcourt_ec pour d'autre tests.

    Normalement mon code devrais être :
    Code PHP : 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
     
    <?php
     
    include "connect.php";
     
    $matricule=$POST[mat]; 
    $nom_info=$POST[nom];
     
    $query = 'select id_ecole, libcourt_ec from mon_ecole where id_ecole=? and libcourt_ec=?';
     
    $prep = $pdo->prepare($query);
     
    //Associer des valeurs aux place holders
    $prep->bindParam(1, $matricule, PDO::PARAM_INT);
    $prep->bindParam(2, $nom_info, PDO::PARAM_STR);
     
    //Compiler et exécuter la requête
    $prep->execute();
     
    //Récupérer toutes les données retournées
    $arrAll = $prep->fetchAll();
    echo $arrAll;
     
    //Clore la requête préparée
    $prep->closeCursor();
    $prep = NULL;
     
    ?>

    le me donne ca !

    D:\wamp64\www\testselect.php:21:
    array (size=1)
    0 =>
    array (size=4)
    'id_ecole' => string '1' (length=1)
    0 => string '1' (length=1)
    'libcourt_ec' => string 'USTCI' (length=5)
    1 => string 'USTCI' (length=5)
    Comment récupérer les valeurs du select dans des variables ?

    Merci

  7. #7
    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
    Comme je t'ai déjà dit, les valeurs du SELECT tu les connais déjà, c'est $matricule et $nom_info.
    N'oubliez pas de consulter les FAQ PHP et les cours et tutoriels PHP

  8. #8
    Membre éprouvé
    Homme Profil pro
    Benevole
    Inscrit en
    Mai 2004
    Messages
    1 679
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Côte d'Ivoire

    Informations professionnelles :
    Activité : Benevole
    Secteur : Enseignement

    Informations forums :
    Inscription : Mai 2004
    Messages : 1 679
    Points : 954
    Points
    954
    Par défaut
    ok d'accord je comprend le but c'est de savoir comment récuperer les valeurs du select dans des variables ? (la syntaxe) puisque après le
    Code php : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
     
    //Compiler et exécuter la requête
    $prep->execute();
     
    //Récupérer toutes les données retournées
    $arrAll = $prep->fetchAll();

    toutes les données sont dans $arrAll !
    le var_dump me donne sous cette forme un peu bizarre !:
    D:\wamp64\www\testselect.php:21:
    array (size=1)
    0 =>
    array (size=4)
    'id_ecole' => string '1' (length=1)
    0 => string '1' (length=1)
    'libcourt_ec' => string 'USTCI' (length=5)
    1 => string 'USTCI' (length=5)
    hors moi je veut les insérer dans des variables j'espère que je suis compris !

    merci

  9. #9
    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
    Ca me désole quand même d'écrire du code qui ne fait rien.
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    $prep->execute();
    if ($row = $prep->fetch(PDO::FETCH_ASSOC)) {
     $id_ecole = $row['id_ecole'];
     $libcourt_ec = $row['libcourt_ec'];
    N'oubliez pas de consulter les FAQ PHP et les cours et tutoriels PHP

  10. #10
    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
    Le but de la requête est peut-être de faire une validation et de faire la suite du traitement uniquement si la ligne existe en base.
    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]

  11. #11
    Membre éprouvé
    Homme Profil pro
    Benevole
    Inscrit en
    Mai 2004
    Messages
    1 679
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Côte d'Ivoire

    Informations professionnelles :
    Activité : Benevole
    Secteur : Enseignement

    Informations forums :
    Inscription : Mai 2004
    Messages : 1 679
    Points : 954
    Points
    954
    Par défaut
    Citation Envoyé par Celira Voir le message
    Le but de la requête est peut-être de faire une validation et de faire la suite du traitement uniquement si la ligne existe en base.
    c'est exactement ce que je voulais faire ! peut être que je m'expliquais mal !

    Merci a Sabotage c'est ce qui me manquais.

    Merci a tous

  12. #12
    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
    oui mais ça ne sert à rien de relire les données dans la table (sauf si on fait une recherche insensible à la casse et qu'on veut récupérer la vraie casse de la donnée).
    N'oubliez pas de consulter les FAQ PHP et les cours et tutoriels PHP

  13. #13
    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
    Tu peux aussi te contenter de compter les lignes avec un count(*) et tester le nombre en résultat :
    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
    $query = 'select count(*) from mon_ecole where id_ecole=? and libcourt_ec=?';
     
    $prep = $pdo->prepare($query);
     
    //Associer des valeurs aux place holders
    $prep->bindParam(1, $matricule, PDO::PARAM_INT);
    $prep->bindParam(2, $nom_info, PDO::PARAM_STR);
     
    //Compiler et exécuter la requête
    $prep->execute();
     
    $nb = $prep->fetchColumn();
     
    if ($nb > 0) {
    // ligne trouvée, on continue
    } else {
    // ligne non trouvée, message d'erreur ?
    }
    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]

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

Discussions similaires

  1. Recupérer la valeur d'un select imbriqué dans un update
    Par miniil dans le forum Langage SQL
    Réponses: 3
    Dernier message: 07/07/2006, 10h49
  2. [Conception] comment recupérer la valeur d'un select
    Par arno1977 dans le forum PHP & Base de données
    Réponses: 2
    Dernier message: 13/06/2006, 14h09
  3. [SQL] Problème de récupération des valeurs d'une liste multiple en php
    Par BOLARD dans le forum PHP & Base de données
    Réponses: 1
    Dernier message: 01/05/2006, 00h29
  4. [VB.NET][2.0]recupérer des valeurs d'un bindingsource
    Par Golzinne dans le forum Windows Forms
    Réponses: 1
    Dernier message: 29/03/2006, 18h43
  5. Réponses: 2
    Dernier message: 20/01/2005, 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