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

Langage SQL Discussion :

selectionner le count et tous les elements d'une table


Sujet :

Langage SQL

  1. #1
    Membre du Club
    Inscrit en
    Juillet 2005
    Messages
    130
    Détails du profil
    Informations forums :
    Inscription : Juillet 2005
    Messages : 130
    Points : 58
    Points
    58
    Par défaut selectionner le count et tous les elements d'une table
    Bonjour tout le monde,

    j'ai un probleme au niveau de sql... sur php, si vous pouvez m'aider je serai vraiment très ravi!

    je voudrai selectionner tout les elements ainsi que le count du ID pour faire un tri

    voici la requete:

    $sql="SELECT *, count(order_id) as number_sales FROM total_orders WHERE site_id=$id and date like '".$date."' order by number_sales asc";

    j'ai aussi essayé:

    $sql="SELECT count(order_id) as number_sales, order_id, date, event_name, price, quantity, profit, order_status FROM total_orders WHERE site_id=$id and date like '".$date."' order by number_sales asc";

    je suis sur de tous les elements, d'ailleur quand j'enleve le count ca marche... sinon je n'ai aucun résultat.

    je vous remerci par avance

  2. #2
    Membre du Club
    Inscrit en
    Octobre 2005
    Messages
    100
    Détails du profil
    Informations forums :
    Inscription : Octobre 2005
    Messages : 100
    Points : 54
    Points
    54
    Par défaut
    ajoute avant ton order by:

  3. #3
    Membre du Club
    Inscrit en
    Juillet 2005
    Messages
    130
    Détails du profil
    Informations forums :
    Inscription : Juillet 2005
    Messages : 130
    Points : 58
    Points
    58
    Par défaut
    Merci pour ta réponse, j'ai essayé ce que tu m'a proposé mais ca ne marvhe toujours pas... je ne comprend pas normalement ca devrait marcher!

  4. #4
    Membre du Club
    Inscrit en
    Octobre 2005
    Messages
    100
    Détails du profil
    Informations forums :
    Inscription : Octobre 2005
    Messages : 100
    Points : 54
    Points
    54
    Par défaut
    essaye alors, tjs avnt ton order by:

  5. #5
    Membre du Club
    Inscrit en
    Juillet 2005
    Messages
    130
    Détails du profil
    Informations forums :
    Inscription : Juillet 2005
    Messages : 130
    Points : 58
    Points
    58
    Par défaut
    en ajoutant group by order id ca donne un résultat mais ca ne le tri pas selon le count.... en plus ca marche seulement si j'enleve le asc ou le desc sinon ca marche pas, ca donne aucun résultat...

    voici la requete qui donne un résultat mais sans le tri:

    $sql="SELECT *, count(order_id) as number_sales FROM total_orders WHERE site_id=$id and date like '".$date."' group by order_id order by number_sales";

    mais si j'ajoute le asc ou le desc ca donne rien...

    merci encore

  6. #6
    Expert éminent sénior

    Avatar de Tofalu
    Homme Profil pro
    Technicien maintenance
    Inscrit en
    Octobre 2004
    Messages
    9 501
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 41
    Localisation : France, Ain (Rhône Alpes)

    Informations professionnelles :
    Activité : Technicien maintenance
    Secteur : Associations - ONG

    Informations forums :
    Inscription : Octobre 2004
    Messages : 9 501
    Points : 32 311
    Points
    32 311
    Par défaut
    Evite d'utiliser le select * avec group by.

    De plus, tous les champs figurant dans le select et ne faisant pas partie d'une fonction d'aggrégat (count, sum, etc) doivent être dans le group by.

    Mais que souhaites tu faire au juste ?

  7. #7
    Membre du Club
    Inscrit en
    Juillet 2005
    Messages
    130
    Détails du profil
    Informations forums :
    Inscription : Juillet 2005
    Messages : 130
    Points : 58
    Points
    58
    Par défaut
    je souhaite selectionner tout simplement tous les elements d'une table et les trier selon le count du ID.... voila

    je voudrai afficher toutes le ventes pour chaque site et les trier selon le nombre de vente...

  8. #8
    Membre expert
    Avatar de TheLeadingEdge
    Inscrit en
    Mai 2005
    Messages
    1 199
    Détails du profil
    Informations forums :
    Inscription : Mai 2005
    Messages : 1 199
    Points : 3 103
    Points
    3 103
    Par défaut
    Si tu veux ttes tes lignes :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    SELECT
    (SELECT COUNT(*) FROM Total_orders WHERE t.order_id = order_id),
    t.*
    FROM total_orders t
    WHERE site_id=$id 
    AND date like '".$date."' 
    ORDER BY 1

  9. #9
    Membre du Club
    Inscrit en
    Juillet 2005
    Messages
    130
    Détails du profil
    Informations forums :
    Inscription : Juillet 2005
    Messages : 130
    Points : 58
    Points
    58
    Par défaut
    merci pour ta réponse TheLeadingEdge

    désolé pour le retard mais c'est que je suis sorti....
    s'il te plait je veux juste préciser que je veux trier selon le count...
    qu'est ce que ca veut dire order by 1?? en tout cas la requte me donne un résultat mais sans tri..

    encore un merci

  10. #10
    Membre du Club
    Inscrit en
    Juillet 2005
    Messages
    130
    Détails du profil
    Informations forums :
    Inscription : Juillet 2005
    Messages : 130
    Points : 58
    Points
    58
    Par défaut
    désolé mais la requete ne marche pas, j'ai oublier d'enregistrer avant e rafraichir...
    est ce que quelqu'un a une solution s'il vous plait....??? je suis vraiment coincé!

    merci

  11. #11
    Membre expert
    Avatar de TheLeadingEdge
    Inscrit en
    Mai 2005
    Messages
    1 199
    Détails du profil
    Informations forums :
    Inscription : Mai 2005
    Messages : 1 199
    Points : 3 103
    Points
    3 103
    Par défaut
    ORDER BY 1 c'est pour trier sur la 1ere colonne du résultat.
    La rq doit fonctionner.
    Peux-tu préciser ton moteur et sa version? Et le message d'erreur (s'il y en a 1) ? Ou quelle est l'erreur ?

  12. #12
    Membre du Club
    Inscrit en
    Juillet 2005
    Messages
    130
    Détails du profil
    Informations forums :
    Inscription : Juillet 2005
    Messages : 130
    Points : 58
    Points
    58
    Par défaut
    Citation Envoyé par TheLeadingEdge
    ORDER BY 1 c'est pour trier sur la 1ere colonne du résultat.
    La rq doit fonctionner.
    Peux-tu préciser ton moteur et sa version? Et le message d'erreur (s'il y en a 1) ? Ou quelle est l'erreur ?
    voici l'erreur:

    You have an error in your SQL syntax near 'SELECT COUNT(*) FROM Total_orders WHERE t.order_id = order_id), t.* FROM total_o' at line 1

    je travail avec mysql, serveur: apache et langage de programamtion: php


    merci encore

  13. #13
    Expert éminent sénior
    Avatar de fsmrel
    Homme Profil pro
    Spécialiste en bases de données
    Inscrit en
    Septembre 2006
    Messages
    8 089
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Essonne (Île de France)

    Informations professionnelles :
    Activité : Spécialiste en bases de données
    Secteur : Conseil

    Informations forums :
    Inscription : Septembre 2006
    Messages : 8 089
    Points : 31 345
    Points
    31 345
    Billets dans le blog
    16
    Par défaut
    Bonjour toddy_101,

    Il faudrait que vous soyez précis quant à la structure de votre table : la colonne Order_Id est-elle clé candidate ?

    Supposons que cela soit le cas. Vous pouvez utiliser une expression de table dans le From (merci à Hugh Darwen qui a convaincu les comités du Standard SQL de la pertinence des expressions de tables) :

    Expression de table :

    Select Count(Order_Id) as Number_Sales from Total_Orders

    From =>

    Select F.*, K.Number_Sales From Total_Orders as F, (Select Count(Order_Id) as Number_Sales from Total_Orders) as K ;

    Je n'ai pas testé la requête et j'ai pu commettre une faute d'orthographe ici ou là. A vous de vérifier.

    Si maintenant Order_Id n’est pas clé :

    Expression de table :

    Select Order_Id, Count (Order_Id) As Number_Sales from Total_Orders Group by Order_Id ;


    From =>

    Select Total_Orders.*, K.Number_Sales From Total_Orders As F, (Select Order_Id, Count (Order_Id) As Number_Sales from Total_Orders Group by Order_Id) As K Where F.Order_Id = K. Order_Id ;

    A vous de vérifier les fautes de frappe...
    (a) Faites simple, mais pas plus simple ! (A. Einstein)
    (b) Certes, E=mc², mais si on discute un peu, on peut l’avoir pour beaucoup moins cher... (G. Lacroix, « Les Euphorismes de Grégoire »)
    => La relativité n'existerait donc que relativement aux relativistes (Jean Eisenstaedt, « Einstein et la relativité générale »)

    __________________________________
    Bases de données relationnelles et normalisation : de la première à la sixième forme normale
    Modéliser les données avec MySQL Workbench
    Je ne réponds pas aux questions techniques par MP. Les forums sont là pour ça.

  14. #14
    Membre du Club
    Inscrit en
    Juillet 2005
    Messages
    130
    Détails du profil
    Informations forums :
    Inscription : Juillet 2005
    Messages : 130
    Points : 58
    Points
    58
    Par défaut
    Citation Envoyé par fsmrel
    Bonjour toddy_101,

    Il faudrait que vous soyez précis quant à la structure de votre table : la colonne Order_Id est-elle clé candidate ?

    Supposons que cela soit le cas. Vous pouvez utiliser une expression de table dans le From (merci à Hugh Darwen qui a convaincu les comités du Standard SQL de la pertinence des expressions de tables) :

    Expression de table :

    Select Count(Order_Id) as Number_Sales from Total_Orders

    From =>

    Select F.*, K.Number_Sales From Total_Orders as F, (Select Count(Order_Id) as Number_Sales from Total_Orders) as K ;

    Je n'ai pas testé la requête et j'ai pu commettre une faute d'orthographe ici ou là. A vous de vérifier.

    Si maintenant Order_Id n’est pas clé :

    Expression de table :

    Select Order_Id, Count (Order_Id) As Number_Sales from Total_Orders Group by Order_Id ;


    From =>

    Select Total_Orders.*, K.Number_Sales From Total_Orders As F, (Select Order_Id, Count (Order_Id) As Number_Sales from Total_Orders Group by Order_Id) As K Where F.Order_Id = K. Order_Id ;

    A vous de vérifier les fautes de frappe...

    merci fsmrel pour le temps consacré....

    je ne sais pas pourquoi j'ai une erreur de syntaxe alors que ta requete semble bien correcte!!

    voici l'erreur:

    You have an error in your SQL syntax near '(Select Count(Order_Id) as Number_Sales from Total_Orders where event_name='Los '

    merci encore

  15. #15
    Membre expert
    Avatar de TheLeadingEdge
    Inscrit en
    Mai 2005
    Messages
    1 199
    Détails du profil
    Informations forums :
    Inscription : Mai 2005
    Messages : 1 199
    Points : 3 103
    Points
    3 103
    Par défaut
    Re,

    Citation Envoyé par toddy_101
    You have an error in your SQL syntax near 'SELECT COUNT(*) FROM Total_orders WHERE t.order_id = order_id), t.* FROM total_o' at line 1
    Tu n'as pas donné la V° de ton moteur. MySQL n'implante les sous-requêtes qu'à partir de la 4.1

  16. #16
    Membre du Club
    Inscrit en
    Juillet 2005
    Messages
    130
    Détails du profil
    Informations forums :
    Inscription : Juillet 2005
    Messages : 130
    Points : 58
    Points
    58
    Par défaut
    Citation Envoyé par TheLeadingEdge
    Re,



    Tu n'as pas donné la V° de ton moteur. MySQL n'implante les sous-requêtes qu'à partir de la 4.1
    la verion de mysql est: 4.1.7

    donc ca devrait marcher?

  17. #17
    Membre expert
    Avatar de TheLeadingEdge
    Inscrit en
    Mai 2005
    Messages
    1 199
    Détails du profil
    Informations forums :
    Inscription : Mai 2005
    Messages : 1 199
    Points : 3 103
    Points
    3 103
    Par défaut
    Re,

    Citation Envoyé par Your MySQL connection
    version: 4.1.14-nt
    Celle là c'est sur. Avant il faudrait demander aux spécialistes de MySQL.

    J'ai 1 question sur ton cumul.
    Tu veux classer sur le total de lignes par site ?
    Mais tes exemples groupent sur order_id ?

    1 petit exemple vite fait en utilisant site_id.

    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
    mysql>
    mysql> SELECT
        -> (SELECT COUNT(*) FROM Orders WHERE O.site_id = site_id) AS "total",
        -> O.*
        -> FROM Orders O
        -> --WHERE site_id=$id
        -> --AND date LIKE '".$date."'
        -> ORDER BY 1 DESC;
    +-------+----------+---------+------------+------------+--------+----------+--------+--------------+
     
    | total | order_id | site_id | order_date | event_name | price  | quantity | profit | order_status |
     
    +-------+----------+---------+------------+------------+--------+----------+--------+--------------+
     
    |     3 |        4 |       3 | 2006-12-28 | event      | 10.000 |        1 |  1.000 | status       |
     
    |     3 |        5 |       3 | 2006-12-28 | event      | 10.000 |        1 |  1.000 | status       |
     
    |     3 |        6 |       3 | 2006-12-28 | event      | 10.000 |        1 |  1.000 | status       |
     
    |     2 |        1 |       1 | 2006-12-28 | event      | 10.000 |        1 |  1.000 | status       |
     
    |     2 |        2 |       1 | 2006-12-28 | event      | 10.000 |        1 |  1.000 | status       |
     
    |     1 |        3 |       2 | 2006-12-28 | event      | 10.000 |        1 |  1.000 | status       |
     
    +-------+----------+---------+------------+------------+--------+----------+--------+--------------+
     
    6 rows in set (0.00 sec)
    A +

Discussions similaires

  1. [Oracle] Requête qui sélectionne tous les champs d'une table et un champ d'une autre table
    Par roswina dans le forum PHP & Base de données
    Réponses: 4
    Dernier message: 04/06/2015, 13h34
  2. [AC-2007] selectionner tous les champs d'une table sauf un seul
    Par Bonero dans le forum Access
    Réponses: 2
    Dernier message: 08/06/2011, 17h54
  3. recuperer tous les elements d'une JList
    Par ejaub dans le forum Composants
    Réponses: 2
    Dernier message: 01/02/2006, 23h12
  4. afficher tous les champs d'une table
    Par julio84 dans le forum ASP
    Réponses: 8
    Dernier message: 19/01/2005, 10h31
  5. Afficher tous les champs d'une table avec dbexpress et MySQL
    Par LHT dans le forum Bases de données
    Réponses: 2
    Dernier message: 25/06/2004, 17h11

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