• Najnowsze pytania
  • Bez odpowiedzi
  • Zadaj pytanie
  • Kategorie
  • Tagi
  • Zdobyte punkty
  • Ekipa ninja
  • IRC
  • FAQ
  • Regulamin
  • Książki warte uwagi

mysql - sorotwanie > grupowanie > sortowanie

Object Storage Arubacloud
0 głosów
814 wizyt
pytanie zadane 21 grudnia 2015 w SQL, bazy danych przez Jolan Obywatel (1,380 p.)

proszę o podpowiedź jak najpierw posortować  np. wg ceny, następnie pogrupować wyniki ,a następnie opsortować


sortowanie > grupowanie  > sortowanie

 

przykładowy kod ale nie działa

    SELECT * FROM 
        (SELECT  `id`, `symbol`, `cecha`, `przeznaczenie`, `cena`  FROM `sklep_online` 
            ORDER BY `cena` DESC
         )AS `tabela` 
    
    WHERE

    `ID` > 2 
    AND
    `przeznaczenie` LIKE "pr_d%"
    
    GROUP BY `symbol`
    ORDER BY `cena`

 

 

 

2 odpowiedzi

0 głosów
odpowiedź 21 grudnia 2015 przez jeremus Maniak (59,720 p.)
nie wiadomo co chcesz osiągnąć ...

sortowanie to wiadomo chcesz sortować po cenie , ale co ma być właściwie grupowane po symbolu ?
komentarz 23 grudnia 2015 przez Jolan Obywatel (1,380 p.)

zakładam ze masz towary w sklepie
np. są to cukierki  producent (a,b,c) 
każda marka ma różne towary i ceny swoich towarów od najtańszych do najdroższych

chodzi o zapytanie takie które odpowie na:

 cukierki od producenta "A" cena od "najtańszy produkt"

 cukierki od producenta "B" cena od "najtańszy produkt" 

 cukierki od producenta "C" cena od "najtańszy produkt"

a następnie posortuje producentów i ich towary po cenie 


 

komentarz 23 grudnia 2015 przez jeremus Maniak (59,720 p.)
wydaje mi się że wystarczy Ci sortowanie..

Pamiętaj że " group by " wymaga użycia funkcji agregującej  

np.

select symbol, param1, param2 from tabela group by symbol

nie zadziała bo dla param1 i param2 musi byc zastosowana funkacja agregująca np. sum , max , min, count, avr itp.. dlatego pytałem co chcesz agregować..

W Twoim przypadku po prostu  :

select symbol,producent,asort,cena from tabela order by symbol,producent,cena

cukierki,producentA,krowki,20

cukierki,producentA,miętówki,30

cukierki,producentB,kasztaniaki,23

-----------

lizaki, producentA,okragle,10

itd

i

a drugie sortowanie w osobnym zapytaniu..

select producent,symbol,asort,cena from tabela order by producent,cena
0 głosów
odpowiedź 25 grudnia 2015 przez mowmiheniek Stary wyjadacz (11,900 p.)

A może coś takiego wystarczy?

SELECT 
    produkt, producent, MIN(cena)
FROM
    tabela
GROUP BY produkt, producent
ORDER BY produkt;

 

Podobne pytania

0 głosów
1 odpowiedź 254 wizyt
+1 głos
1 odpowiedź 357 wizyt
0 głosów
2 odpowiedzi 300 wizyt
pytanie zadane 29 września 2015 w PHP przez tytanik2011 Użytkownik (930 p.)

92,579 zapytań

141,432 odpowiedzi

319,664 komentarzy

61,965 pasjonatów

Motyw:

Akcja Pajacyk

Pajacyk od wielu lat dożywia dzieci. Pomóż klikając w zielony brzuszek na stronie. Dziękujemy! ♡

Oto polecana książka warta uwagi.
Pełną listę książek znajdziesz tutaj.

Akademia Sekuraka

Kolejna edycja największej imprezy hakerskiej w Polsce, czyli Mega Sekurak Hacking Party odbędzie się już 20 maja 2024r. Z tej okazji mamy dla Was kod: pasjamshp - jeżeli wpiszecie go w koszyku, to wówczas otrzymacie 40% zniżki na bilet w wersji standard!

Więcej informacji na temat imprezy znajdziecie tutaj. Dziękujemy ekipie Sekuraka za taką fajną zniżkę dla wszystkich Pasjonatów!

Akademia Sekuraka

Niedawno wystartował dodruk tej świetnej, rozchwytywanej książki (około 940 stron). Mamy dla Was kod: pasja (wpiszcie go w koszyku), dzięki któremu otrzymujemy 10% zniżki - dziękujemy zaprzyjaźnionej ekipie Sekuraka za taki bonus dla Pasjonatów! Książka to pierwszy tom z serii o ITsec, który łagodnie wprowadzi w świat bezpieczeństwa IT każdą osobę - warto, polecamy!

...