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 :

[SQL] Requete avec ordre correspondant à la clause WHERE


Sujet :

PHP & Base de données

  1. #1
    Membre du Club
    Profil pro
    Inscrit en
    Janvier 2005
    Messages
    49
    Détails du profil
    Informations personnelles :
    Localisation : Belgique

    Informations forums :
    Inscription : Janvier 2005
    Messages : 49
    Points : 41
    Points
    41
    Par défaut [SQL] Requete avec ordre correspondant à la clause WHERE
    Bonjour,

    J'effectue la requete suivante :
    $query = "SELECT ID,TITRE,DATE FROM vdo WHERE ID='7239' OR ID='5301' OR ID='6750'";

    Lorsque j'affiche ces resultat, il s'affichent de 5301 puis 6750 puis 7239 or ce que j'aimerai c'est qu'il s'affichent en fonction de l'ordre de la clause WHERE c'est à dire 7239, 6750, 5301.

    Je ne les tri pas via l'id parce que je recuprère cet ordre d'un traitement php.

    QQ'un connaitrait une possibilité ?

    D'avance Merci

  2. #2
    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
    Salut

    C'est un tri décroissant par rapport à ID ou juste une coïncidence ?

  3. #3
    Membre du Club
    Profil pro
    Inscrit en
    Janvier 2005
    Messages
    49
    Détails du profil
    Informations personnelles :
    Localisation : Belgique

    Informations forums :
    Inscription : Janvier 2005
    Messages : 49
    Points : 41
    Points
    41
    Par défaut
    Salut,

    J'me suis planté ds ce que j'aimerai obtenir : 7239, 5301, 6750.
    Donc c'est pas un tri decroissant par rapport à ID

  4. #4
    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
    Je ne pense pas que ce soit possible par sql. En revanche comme tes valeurs proviennent d'un traitement php, on peut peut-être creuser de ce côté.

    D'où : peux-tu donner le code qui va avec ta requête?

  5. #5
    Membre du Club
    Profil pro
    Inscrit en
    Janvier 2005
    Messages
    49
    Détails du profil
    Informations personnelles :
    Localisation : Belgique

    Informations forums :
    Inscription : Janvier 2005
    Messages : 49
    Points : 41
    Points
    41
    Par défaut
    En fait je construit ma requete comme ça :
    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
    $AND = "";
     
    $i = 1;
    foreach ($arrcontenu as $key => $val) {   
    	$decomp=explode(":",$val);
    	$ID= $decomp[0];
     
    	if(($val != "") AND ($i >= $debut) AND ($i <= $fin)){
    		IF($i == $debut){
    			$AND .= " ID ='".$ID."'";
    		}
    		ELSE{
    			$AND .= " OR ID ='".$ID."'";
    		}
    	}
     
    	$i++;
    }
    Les données proviennent d'un array qui a été trié via usort ...

    le $AND me donne la clause WHERE.

    Merci pour ton aide

  6. #6
    Membre du Club
    Profil pro
    Inscrit en
    Janvier 2005
    Messages
    49
    Détails du profil
    Informations personnelles :
    Localisation : Belgique

    Informations forums :
    Inscription : Janvier 2005
    Messages : 49
    Points : 41
    Points
    41
    Par défaut
    SELECT ID,TITRE,DATE FROM vdo WHERE ID IN ( '7239', '5301', '6750' ) ORDER BY FIELD(id, '7239', '5301', '6750')

    Si jms ça interesse qq'un

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

Discussions similaires

  1. [SQL] requete avec where dynamique
    Par Wells dans le forum Développement
    Réponses: 8
    Dernier message: 05/06/2008, 17h50
  2. Réponses: 3
    Dernier message: 18/09/2006, 20h55
  3. [SQL] Requête avec "valeur si null"
    Par metalcoyote dans le forum Oracle
    Réponses: 3
    Dernier message: 19/04/2006, 10h22
  4. PL/SQL requete avec UNION
    Par lapartdombre dans le forum PL/SQL
    Réponses: 3
    Dernier message: 17/11/2005, 08h40
  5. [SQL]Requete avec 2 count(*) sur la même table
    Par Sonny dans le forum Langage SQL
    Réponses: 5
    Dernier message: 06/11/2005, 16h41

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