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 :

Ecriture d'une requête


Sujet :

PHP & Base de données

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre éclairé
    Profil pro
    Inscrit en
    Août 2007
    Messages
    412
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Août 2007
    Messages : 412
    Par défaut Ecriture d'une requête
    Bonjour à tous

    j'ai un problème je crois que la fatigue me gagne j'ai les yeux injectés de sang (c'est bientôt halloween )

    Bref voici mon souci

    de la page 1 à la page 2 j'arrive bien à transférer une donnée via la fonction $_GET ca pas de problème

    la bonne donnée s'affiche bien sur la page 2 via ce bout de code

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
     
    $vehicule = $_GET['vehicule'];
    echo $vehicule;
    j'aimerai sur la page 2 filtrer mes résultats en utilisant la variable $vehicule mais la gros souci j'ai des erreurs, ce doit etre un souci d'écriture mais je n'y arrive plus

    avez vous une idée

    voici ma requête :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
     
    $select = 'SELECT * FROM anomalies WHERE vehicule = $vehicule';
    Merci de votre aide

  2. #2
    Modérateur

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

    Informations professionnelles :
    Activité : DBA
    Secteur : Service public

    Informations forums :
    Inscription : Juin 2005
    Messages : 5 506
    Par défaut
    Il faut connaître la différence entre sigle quote '' et double quote ""

    En single quote la variable sera lue comme du texte et donc afficheras $vehicule tel quel.
    En double quote la variable est interprété et donc sont contenu sera lu.

    Donc simplement ceci et cela fonctionneras

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
     
    $select = "SELECT * FROM anomalies WHERE vehicule = $vehicule";
    Bien sur une concaténation est aussi possible.

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
     
    $select = 'SELECT * FROM anomalies WHERE vehicule = '.$vehicule;

    Maintenant pour des requêtes de base de données, je te conseille de te renseigner sur les requête préparé et PDO

  3. #3
    Membre éclairé
    Profil pro
    Inscrit en
    Août 2007
    Messages
    412
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Août 2007
    Messages : 412
    Par défaut
    Bonjour MaitrePylos, merci de m'avoir répondu et merci pour le petit cours sur les QUOTE car en tant qu'autodidacte je ne connaissais pas cette subtilité, j'ai toujours travailler de la même façon et sans problème jusque la lol.

    J'ai appliqué votre méthode mais il subsiste toujours des problèmes.

    C'est étonnant car j'utilise ce même genre de script dans d'autres tableaux et la pas de souci. je ne pige plus peut être suis-je en BURN OUT

    voici mon code complet :

    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
     
     
     
     
    <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
    <html xmlns="http://www.w3.org/1999/xhtml">
    <head>
    <meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
    <title>Document sans titre</title>
    </head>
    <body>
    <?php
     
     
    // information pour la connection à le DB
    include('config.php');
     
     
    $vehicule = $_GET['vehicule'];
    echo $vehicule;
     
     
    //echo '<font color="white">c\'est ok</font>';
    $select = "SELECT * FROM anomalies WHERE vehicule = $vehicule";	
    $result = $conn->query($select);
    $total = mysqli_num_rows($result);
    if($total) {
     
     
    // debut du tablea'
     
     
    echo '<table align="center" bgcolor="#FFFFFF">'."\n";
    echo '<tr>';// debut
    echo '<td align="center"; style="color:white" bgcolor="#0072ff"><b><u>VEHICULE</u></b></td>';			
    echo '</tr>'."\n";// fin
     
     
    // lecture et affichage des résultats sur 2 colonnes, 1 résultat par ligne.   
     
     
    while($row = mysqli_fetch_array($result)) {
    echo '<tr>';//debut
    echo '<td align="left"; style="color:black"; bgcolor="#CCCCCC"  title="" >'.$row["vehicule"].'</td>';	
    }
    echo '</table>'."\n";
    }
    // fin du tableau.
    else echo '<br>Aucun Enregistrement';
    // on libère le résultat
    mysqli_free_result($result);
     
     
    ?>
    </body>
    </html>
    et voici les erreurs :

    AvertissementBEA : mysqli_num_rows() s’attend à ce que le paramètre 1 soit mysqli_result, booléen donné dans D:\xampp\htdocs\csp-cherbourg\csp\standard\filtre_anomalie.php en ligne 20

    Aucun Enregistrement

    Warning: mysqli_free_result() s’attend à ce que le paramètre 1 soit mysqli_result, booléen donné en D:\xampp\htdocs\csp-cherbourg\csp\standard\filtre_anomalie.php en ligne 41

    Merci de votre aide si précieuse

  4. #4
    Modérateur

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

    Informations professionnelles :
    Activité : DBA
    Secteur : Service public

    Informations forums :
    Inscription : Juin 2005
    Messages : 5 506
    Par défaut
    Bonjour,

    Je vais supposer que l'attribut véhicule de votre table de db est de type varchar (string).

    Si oui, autre petite subtilité

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    $select = "SELECT * FROM anomalies WHERE vehicule = '$vehicule'";

  5. #5
    Membre éclairé
    Profil pro
    Inscrit en
    Août 2007
    Messages
    412
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Août 2007
    Messages : 412
    Par défaut
    vehicule est un type TEXT

  6. #6
    Membre éclairé
    Profil pro
    Inscrit en
    Août 2007
    Messages
    412
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Août 2007
    Messages : 412
    Par défaut
    Votre ligne de code fonctionne très bien

    Merci Merci, je me tirais les cheveux depuis des jours

    Pourriez-vous m'expliquer la subtilité SVP

    Encore merci

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

Discussions similaires

  1. [MySQL] Ecriture d'une requête
    Par jmtrivia dans le forum PHP & Base de données
    Réponses: 19
    Dernier message: 11/04/2019, 21h02
  2. Réponses: 2
    Dernier message: 11/08/2017, 16h38
  3. Ecriture d'une requète
    Par atk_49 dans le forum Langage SQL
    Réponses: 2
    Dernier message: 10/02/2015, 10h34
  4. [AJAX] Ecriture dans un fichier json avec une requête AJAX
    Par DarkPoster14 dans le forum jQuery
    Réponses: 1
    Dernier message: 10/07/2012, 09h45
  5. Ecriture d'une variable dans une requête
    Par papilou86 dans le forum Access
    Réponses: 2
    Dernier message: 02/06/2006, 09h03

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