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 :

Paramètre de requête non pris en compte


Sujet :

PHP & Base de données

  1. #1
    Futur Membre du Club
    Inscrit en
    Octobre 2009
    Messages
    22
    Détails du profil
    Informations forums :
    Inscription : Octobre 2009
    Messages : 22
    Points : 8
    Points
    8
    Par défaut Paramètre de requête non pris en compte
    Bonjour a tous,

    Je cherche a afficher les informations de musiques contenu dans ma table tracks en fonction des criteres BPM, GENRE, AMBIENT, METATAGS correspondant a des checkbox cochées dans un formulaire.

    Mon probleme est que la recherche doit se faire sur les musiques dont le champ ETATTRACK est a 'on'.
    Mais la requete ne tient pas compte de ETATTRACK et affiche les resultats.


    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    SELECT * FROM tracks 
    WHERE keytrack>1 
    AND `etattrack`= 'on' 
    AND `bpm` LIKE '%vslow%' 
    AND `genre` LIKE '%atmospheric%' 
    OR `genre` LIKE '%ambient%' 
    OR `genre` LIKE '%breaks%' 
    AND `metatags` LIKE '%%'
    ORDER BY idtrack 
    LIMIT 0,20
    Avez-vous une solution?

    Cordialement

  2. #2
    Expert confirmé Avatar de Cybher
    Homme Profil pro
    Consultant réseaux et sécurité
    Inscrit en
    Mai 2005
    Messages
    3 281
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 41
    Localisation : France

    Informations professionnelles :
    Activité : Consultant réseaux et sécurité
    Secteur : Conseil

    Informations forums :
    Inscription : Mai 2005
    Messages : 3 281
    Points : 4 644
    Points
    4 644
    Par défaut
    salut,

    avec des parenthèses?
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    SELECT * FROM tracks 
    WHERE keytrack>1 
    AND `etattrack`= 'on' 
    AND `bpm` LIKE '%vslow%' 
    AND 
    (`genre` LIKE '%atmospheric%' 
    OR `genre` LIKE '%ambient%' 
    OR `genre` LIKE '%breaks%' ) 
    AND `metatags` LIKE '%%'
    ORDER BY idtrack 
    LIMIT 0,20

  3. #3
    Futur Membre du Club
    Inscrit en
    Octobre 2009
    Messages
    22
    Détails du profil
    Informations forums :
    Inscription : Octobre 2009
    Messages : 22
    Points : 8
    Points
    8
    Par défaut
    Merci pour ta reponse. En effet ca marche bien dans ma phpmyadmin mais mon code pour la requete est comme ceci. Du coup je vois pas trop comment mettre mes parentheses vu que je decompose ma requete

    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
    62
    63
    64
    65
    66
    67
    68
    69
    70
    71
    72
    73
    74
    75
    76
    77
    78
    79
     
    $query = "SELECT * FROM tracks";
     
    		$num_bpm = count($_POST["BPM"]);
    		$num_genre = count($_POST["GENRE"]);
    		$num_source = count($_POST["SOURCE"]);
    		$num_timbre =  count($_POST["TIMBRE"]);
    		$num_instrument = count($_POST["INSTRUMENT"]);
    		$num_keyword = count($_POST["KEYWORD"]);
     
     
    		// Control DATA
    		// $num_bpm.":".$num_genre.":".$num_source.":".$num_timbre.":".$num_instrument.":".$num_keyword;
     
    		// We add the first component of our request
    		if($num_bpm != 0 || $num_genre != 0 || $num_source != 0 || $num_timbre != 0 || $num_instrument != 0 || $num_keyword != 0) { $query .= " WHERE keytrack>1 AND `etattrack`= 'on' "; }
     
     
     
    		// BPM DATA
    		for($i=0;$i<$num_bpm;$i++){
     
    			if($i == 0){
    				$query .= " AND `bpm` LIKE '%".$_POST["BPM"][$i]."%'";
    			}else{
    				$query .= " OR `bpm` LIKE '%".$_POST["BPM"][$i]."%'";
    			}		
    		}
     
    		// GENRE DATA
    		for($j=0;$j<$num_genre;$j++){
     
    			if($j == 0){
    				$query .= " AND `genre` LIKE '%".$_POST["GENRE"][$j]."%'";
    			}else{
    				$query .= " OR `genre` LIKE '%".$_POST["GENRE"][$j]."%'";
    			}		
    		}
     
    		// SOURCE DATA
    		for($k=0;$k<$num_source;$k++){
     
    			if($k == 0){
    				$query .= " AND `source` LIKE '%".$_POST["SOURCE"][$k]."%'";
    			}else{
    				$query .= " OR `source` LIKE '%".$_POST["SOURCE"][$k]."%'";
    			}		
    		}
     
    		// Timbre DATA
    		for($g=0;$g<$num_timbre;$g++){
     
    			if($g == 0){
    				$query .= " AND `timbre` LIKE '%".$_POST["TIMBRE"][$g]."%'";
    			}else{
    				$query .= " OR `timbre` LIKE '%".$_POST["TIMBRE"][$g]."%'";
    			}		
    		}
     
    		// INSTRUMENT DATA
    		for($e=0;$e<$num_instrument;$e++){
     
    			if($e == 0){
    				$query .= " AND `instrumentation` LIKE '%".$_POST["INSTRUMENT"][$e]."%'";
    			}else{
    				$query .= " OR `instrumentation` LIKE '%".$_POST["INSTRUMENT"][$e]."%'";
    			}		
    		}
     
     
    		// KEYWORD DATA
    		for($r=0;$r<$num_keyword;$r++){
     
    			if($r == 0){
    				$query .= " AND `metatags` LIKE '%".$_POST["KEYWORD"][$r]."%'";
    			}else{
    				$query .= " OR `metatags` LIKE '%".$_POST["KEYWORD"][$r]."%' )";
    			}		
    		}

  4. #4
    ced
    ced est déconnecté
    Rédacteur/Modérateur

    Avatar de ced
    Homme Profil pro
    Gestion de bases de données techniques
    Inscrit en
    Avril 2002
    Messages
    6 039
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 49
    Localisation : France, Loiret (Centre)

    Informations professionnelles :
    Activité : Gestion de bases de données techniques
    Secteur : Agroalimentaire - Agriculture

    Informations forums :
    Inscription : Avril 2002
    Messages : 6 039
    Points : 23 787
    Points
    23 787
    Par défaut
    Là, ça devient un problème de PHP...

    ced

  5. #5
    Membre habitué
    Inscrit en
    Juillet 2009
    Messages
    156
    Détails du profil
    Informations forums :
    Inscription : Juillet 2009
    Messages : 156
    Points : 160
    Points
    160
    Par défaut
    juste un bout, et comme ceci tes for???:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    // BPM DATA
    		$query .= " AND (" ;
    		for($i=0;$i<$num_bpm;$i++){
     
    			if($i == 0){
    				$query .= " `bpm` LIKE '%".$_POST["BPM"][$i]."%'";
    			}else{
    				$query .= " OR `bpm` LIKE '%".$_POST["BPM"][$i]."%'";
    			}		
    		}
    		$query .= " ) ";
    question, pourquoi faire toutes les lettres de l'alphabet??? ton $i par a la poubelle apres le premier for, autant le reprendre pour les autres

    et sinon tu as quoi en alternative si toutes tes valeur sont égale à 0 ???
    une autre remarque, c'est moi ou personne ne protège ses requêtes SQL???

Discussions similaires

  1. Réponses: 4
    Dernier message: 10/11/2010, 22h01
  2. [CR XI] Paramètre d'entrée non pris en compte
    Par grochatisen dans le forum SDK
    Réponses: 0
    Dernier message: 16/07/2010, 14h21
  3. paramètres entrés mais non pris en compte
    Par lecamer dans le forum VB 6 et antérieur
    Réponses: 11
    Dernier message: 24/06/2008, 13h06
  4. [HTACCESS] Paramètres non pris en compte
    Par alexfrere dans le forum Apache
    Réponses: 1
    Dernier message: 30/01/2007, 21h17
  5. Accents non pris en compte dans les requêtes SELECT
    Par YanK dans le forum Requêtes
    Réponses: 1
    Dernier message: 30/08/2005, 10h57

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