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 :

Insertion de ORDER BY


Sujet :

PHP & Base de données

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre actif
    Homme Profil pro
    Étudiant
    Inscrit en
    Avril 2013
    Messages
    82
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Loiret (Centre)

    Informations professionnelles :
    Activité : Étudiant
    Secteur : Industrie

    Informations forums :
    Inscription : Avril 2013
    Messages : 82
    Par défaut Insertion de ORDER BY
    Bonjour,

    Avez vous une idée de comment je peux insérer un ORDER BY dans une requète ?

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    foreach($mots as $mot)
            {
    $sql.="SELECT * FROM afficher,doc WHERE  afficher.idqrqc = doc.idqrqc and  code='$code1' and zone='$zone1'  $sql_types and titre LIKE '%$mot%' UNION ";
     }
    //quand la boucle est terminée, il faut enlever le dernier union
    $sql=substr($sql,0,-6);
     
     
    $req = mysql_query($sql, $cnx) 
     		   or 
     		  die("Pb dans la requête : " . mysql_error($cnx));
     
     }
    quand je le met à coté de Union il m'affiche ce message :

    Pb dans la requête : You have an error in your SQL syntax; check the manual that corresponds to your MySQL server version for the right syntax to use near ' ORDER BY iddoc' at line 1
    Merci.

  2. #2
    Rédacteur

    Avatar de Torgar
    Homme Profil pro
    Développeur Web
    Inscrit en
    Août 2007
    Messages
    2 334
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 39
    Localisation : France, Hérault (Languedoc Roussillon)

    Informations professionnelles :
    Activité : Développeur Web

    Informations forums :
    Inscription : Août 2007
    Messages : 2 334
    Par défaut
    Salut,

    Montre nous la requête générée que tu exécutes.

    À vue de nez je dirais qu'il faut faire un SELECT de toute ta requête UNION et de faire le ORDER BY sur ce SELECT.
    Je ne suis pas schizophrène, nous sommes unanime !!!

    ► Pensez à la balise code et au CODE HTML GENERE !!!!
    ► Au si c'est le cas et au à ceux qui vous ont aidé.
    Vous souhaitez participer aux rubriques CSS et (X)HTML ? Contactez-nous !

    Créer des colonnes de même hauteur en CSS
    Glossaire CSS
    Les bordures en CSS3
    Les transitions en CSS3

  3. #3
    Membre actif
    Homme Profil pro
    Étudiant
    Inscrit en
    Avril 2013
    Messages
    82
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Loiret (Centre)

    Informations professionnelles :
    Activité : Étudiant
    Secteur : Industrie

    Informations forums :
    Inscription : Avril 2013
    Messages : 82
    Par défaut
    Citation Envoyé par Torgar Voir le message

    Montre nous la requête générée que tu exécutes.
    .
    je ne vois de quoi tu parles ?

    req c'est la requète

    j'ai fait union pour faire une recherche par mots clés

    j'ajoute ça biensur

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    $listeqrqc = mysql_fetch_object($req);

  4. #4
    Rédacteur

    Avatar de Torgar
    Homme Profil pro
    Développeur Web
    Inscrit en
    Août 2007
    Messages
    2 334
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 39
    Localisation : France, Hérault (Languedoc Roussillon)

    Informations professionnelles :
    Activité : Développeur Web

    Informations forums :
    Inscription : Août 2007
    Messages : 2 334
    Par défaut
    Bah tu boucles en faisant des UNION donc je présume que ta requête doit ressembler à quelque chose comme ça :

    Code sql : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    SELECT * FROM afficher,doc WHERE  afficher.idqrqc = doc.idqrqc and  code='AA' and zone='BB'  $sql_types and titre LIKE '%coincoin%' UNION
    SELECT * FROM afficher,doc WHERE  afficher.idqrqc = doc.idqrqc and  code='BB' and zone='ZZ'  $sql_types and titre LIKE '%banzai%' UNION
    SELECT * FROM afficher,doc WHERE  afficher.idqrqc = doc.idqrqc and  code='TOTO' and zone='TITI'  $sql_types and titre LIKE '%pouet%' ORDER BY code
    C'est ça que je demandais, le résultat d'un echo $sql; après ta boucle for().
    Et naturellement ça ne fonctionne pas.

    Ce qu'il faudrait faire c'est :
    Code sql : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    SELECT * FROM
    (
    	SELECT * FROM afficher, doc WHERE afficher.idqrqc = doc.idqrqc AND code='AA' and zone='BB' $sql_types and titre LIKE '%coincoin%'
    	UNION
    	SELECT * FROM afficher, doc WHERE afficher.idqrqc = doc.idqrqc AND code='BB' and zone='ZZ' $sql_types and titre LIKE '%banzai%'
    	UNION
    	SELECT * FROM afficher, doc WHERE afficher.idqrqc = doc.idqrqc AND code='TOTO' and zone='TITI' $sql_types and titre LIKE '%pouet%'
    ) AS R
    ORDER BY R.code

    À essayer.
    Je ne suis pas schizophrène, nous sommes unanime !!!

    ► Pensez à la balise code et au CODE HTML GENERE !!!!
    ► Au si c'est le cas et au à ceux qui vous ont aidé.
    Vous souhaitez participer aux rubriques CSS et (X)HTML ? Contactez-nous !

    Créer des colonnes de même hauteur en CSS
    Glossaire CSS
    Les bordures en CSS3
    Les transitions en CSS3

  5. #5
    Membre actif
    Homme Profil pro
    Étudiant
    Inscrit en
    Avril 2013
    Messages
    82
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Loiret (Centre)

    Informations professionnelles :
    Activité : Étudiant
    Secteur : Industrie

    Informations forums :
    Inscription : Avril 2013
    Messages : 82
    Par défaut
    euuuh c'est évident que le résultat est :

    Code sql : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    SELECT * FROM afficher,doc WHERE  afficher.idqrqc = doc.idqrqc AND  code='AA' AND zone='BB'  $sql_types AND titre LIKE '%coincoin%' UNION
    SELECT * FROM afficher,doc WHERE  afficher.idqrqc = doc.idqrqc AND  code='BB' AND zone='ZZ'  $sql_types AND titre LIKE '%banzai%' UNION

    Par contre je ne vois pas comment appliquer ton exemple !

Discussions similaires

  1. ORDER BY RAND() ne fonctionne pas dans INSERT
    Par cedrick21 dans le forum Requêtes
    Réponses: 1
    Dernier message: 17/08/2010, 11h46
  2. Réponses: 1
    Dernier message: 05/06/2009, 18h17
  3. Ordre d'insertion = order by rowid ?
    Par Sokaar dans le forum SQL
    Réponses: 12
    Dernier message: 26/11/2008, 09h04
  4. Order by dans un Insert into
    Par fardon57 dans le forum SQL
    Réponses: 11
    Dernier message: 13/11/2008, 15h35
  5. insert into et order by
    Par zdagzdag dans le forum Requêtes
    Réponses: 4
    Dernier message: 11/11/2008, 21h20

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