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 :

Requête ne renvoie pas tous les résultats


Sujet :

PHP & Base de données

  1. #1
    Futur Membre du Club
    Homme Profil pro
    Collégien
    Inscrit en
    Février 2015
    Messages
    10
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Canada

    Informations professionnelles :
    Activité : Collégien

    Informations forums :
    Inscription : Février 2015
    Messages : 10
    Points : 7
    Points
    7
    Par défaut Requête ne renvoie pas tous les résultats
    Bonjour à vous,

    Je suis en train de faire un système d’autocomplétion en JavaScript et bizarrement, il n'y a que 2 sortie de la base de données qui sont les mêmes. Le problème ne vient pas de l'autocomplétion parce que j'ai essayé de sortir les données avec d'autres façons et toujours le même résultat.

    Le résultat est toujours dollarama 2 fois qui à le premier id, ou si je l'efface c l'id suivant.

    J'ai tenter de trouver des réponses sur le web, mais rien qui explique pourquoi j'ai ce problème, pour cette raison que je fais appel à votre aide d'expert.

    Voici la partie serveur :
    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
    <?php
        try {$bdd=new PDO('mysql:host=localhost;dbname=test;charset=utf8', 'root','');}
        catch(Exception $e){die('Erreur : '.$e->getMessage());}
            $req = $bdd->query('SELECT entreprise FROM entreprises ');
                $data = $req->fetch();
                 $dataLen = count($data);
                 sort($data);
                 $results = array();
                for($i=0 ; $i<$dataLen && count($results)<10 ;$i++ ){
                    if(stripos($data[$i], $_GET['s'])===0){
                        array_push($results,$data[$i]);
                    }
                }
                echo implode('|', $results);
    ?>
    Merci de votre aide et votre temps.

  2. #2
    Rédacteur

    Avatar de Bovino
    Homme Profil pro
    Développeur Web
    Inscrit en
    Juin 2008
    Messages
    23 647
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 54
    Localisation : France, Gironde (Aquitaine)

    Informations professionnelles :
    Activité : Développeur Web
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Juin 2008
    Messages : 23 647
    Points : 91 220
    Points
    91 220
    Billets dans le blog
    20
    Par défaut
    Heu... tu es sûr de vraiment comprendre ce que tu fais ?

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    while($data = $rep->fetch()){
    Dans ton while, tu récupères (avec fetch()) une ligne de résultat, or avec ta requête
    Code sql : Sélectionner tout - Visualiser dans une fenêtre à part
    SELECT DISTINCT entreprise FROM entreprises_unicaerus
    une ligne correspond à une seule valeur (entreprise) donc $dataLen = count($data); vaudra toujours 1 et sort($data); devient un peu inutile et ta boucle for encore plus.
    D'autre part, pourquoi faire un echo à chaque itération du while ?

    Pour finir, pourquoi n'intègres-tu pas le paramètre de recherche directement dans ta requête ?

  3. #3
    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
    Logique : la fonction fetch de PDO remonte uniquement la 1ere ligne du jeu de résultat.
    Si tu veux toutes les lignes, il faut soit faire une boucle, soit utiliser fetchAll

  4. #4
    Futur Membre du Club
    Homme Profil pro
    Collégien
    Inscrit en
    Février 2015
    Messages
    10
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Canada

    Informations professionnelles :
    Activité : Collégien

    Informations forums :
    Inscription : Février 2015
    Messages : 10
    Points : 7
    Points
    7
    Par défaut
    Merci beaucoup pour votre aide!

    J'ai modifier le code et je suis rendu à

    code serveur :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    <?php
    try {$bdd=new PDO('mysql:host=localhost;dbname=test;charset=utf8', 'root','');}
    catch(Exception $e){die('Erreur : '.$e->getMessage());}
    $req = $bdd->prepare('SELECT entreprise*FROM entreprises*WHERE entreprise=? ORDER BY entreprise');
    $req->execute(array($_GET['s']));
    $datas = $req->fetchAll();
    echo implode('|', $datas);
    ?>
    et le script
    Code javascript : 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
    62
    63
    64
    65
    66
    67
    68
    69
    70
    71
    72
    73
    74
    75
    76
    77
    78
    79
    80
    81
    82
    83
    84
    85
    86
    87
    88
    89
    90
    91
    92
    93
    94
    95
    96
    97
    98
    99
    100
    101
    102
    103
    104
    105
    106
    107
    108
    109
    110
    111
    112
    (function() {
    	var searchElement = document.getElementById('search'),
    	results = document.getElementById('results'),
    	selectedResult = -1, // Permet de savoir quel résultat est sélectionné : -1 signifie "aucune sélection"
    	previousRequest, // On stocke notre précédente requête dans cette variable
    	previousValue = searchElement.value; // On fait de même avec la précédente valeur
    	function getResults(keywords) { // Effectue une requête et récupère les résultats
     
    	var xhr = new XMLHttpRequest();
    	xhr.open('GET', 'autocompletionConf.php?s='+ encodeURIComponent(keywords));
     
    	xhr.addEventListener('readystatechange', function() {
    	if (xhr.readyState == 4 && xhr.status == 200) {
     
    	displayResults(xhr.responseText);
     
    	}
    	}, false);
     
    	xhr.send(null);
     
    	return xhr;
     
    	}
     
    	function displayResults(response) { // Affiche les résultats d'une requête
     
    	results.style.display = response.length ? 'block' : 'none'; // On cache le conteneur si on n'a pas de résultats
     
    	if (response.length) { // On ne modifie les résultats que si on en a obtenu
     
    	response = response.split('|');
    	var responseLen = response.length;
     
    	results.innerHTML = ''; // On vide les résultats
     
    	for (var i = 0, div ; i < responseLen ; i++) {
     
    	div = results.appendChild(document.createElement('div'));
    	div.innerHTML = response[i];
     
    	div.addEventListener('click', function(e) {
    	chooseResult(e.target);
    	}, false);
     
    	}
     
    	}
     
    	}
     
    	function chooseResult(result) { // Choisi un des résultats d'une requête et gère tout ce qui y est attaché
     
    	searchElement.value = previousValue = result.innerHTML; // On change le contenu du champ de recherche et on enregistre en tant que précédente valeur
    	results.style.display = 'none'; // On cache les résultats
    	result.className = ''; // On supprime l'effet de focus
    	selectedResult = -1; // On remet la sélection à "zéro"
    	searchElement.focus(); // Si le résultat a été choisi par le biais d'un clique alors le focus est perdu, donc on le réattribue
     
    	}
     
     
     
    	searchElement.addEventListener('keyup', function(e) {
     
    	var divs = results.getElementsByTagName('div');
     
    	if (e.keyCode == 38 && selectedResult > -1) { // Si la touche pressée est la flèche "haut"
     
    	divs[selectedResult--].className = '';
     
    	if (selectedResult > -1) { // Cette condition évite une modification de childNodes[-1], qui n'existe pas, bien entendu
    	divs[selectedResult].className = 'result_focus';
    	}
     
    	}
     
    	else if (e.keyCode == 40 && selectedResult < divs.length - 1) { // Si la touche pressée est la flèche "bas"
     
    	results.style.display = 'block'; // On affiche les résultats
     
    	if (selectedResult > -1) { // Cette condition évite une modification de childNodes[-1], qui n'existe pas, bien entendu
    	divs[selectedResult].className = '';
    	}
     
    	divs[++selectedResult].className = 'result_focus';
     
    	}
     
    	else if (e.keyCode == 13 && selectedResult > -1) { // Si la touche pressée est "Entrée"
     
    	chooseResult(divs[selectedResult]);
     
    	}
     
    	else if (searchElement.value != previousValue) { // Si le contenu du champ de recherche a changé
     
    	previousValue = searchElement.value;
     
    	if (previousRequest && previousRequest.readyState < 4) {
    	previousRequest.abort(); // Si on a toujours une requête en cours, on l'arrête
    	}
     
    	previousRequest = getResults(previousValue); // On stocke la nouvelle requête
     
    	selectedResult = -1; // On remet la sélection à "zéro" à chaque caractère écrit
     
    	}
     
    	}, false);
     
    	})();

    et au besoin html

    Code html : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    <form action="Configuration/rechercheConf.php" method="POST">
    		<label>Recherche d'une entreprise : </label><input type="search" id="search" name="recherche" autocomplete="off"  autofocus/>	
     
    		<input type="submit" value="Rechercher" />
    		<div id="results"></div>
    	</form>

Discussions similaires

  1. Jointure qui ne renvoie pas tous les enregistrements
    Par rayonx dans le forum Langage SQL
    Réponses: 12
    Dernier message: 19/07/2024, 09h33
  2. ma requête ne m'affiche pas tous les résultats
    Par gastoncs dans le forum Requêtes
    Réponses: 6
    Dernier message: 07/11/2012, 11h37
  3. [MySQL] mon select ne renvoie pas tous les champs
    Par dhonore dans le forum PHP & Base de données
    Réponses: 1
    Dernier message: 25/07/2011, 16h00
  4. Jointure ne donnant pas tous les résultats
    Par chaours dans le forum Requêtes
    Réponses: 14
    Dernier message: 09/07/2010, 11h56
  5. Réponses: 3
    Dernier message: 18/11/2008, 15h31

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