Witaj Gościu! ( Zaloguj | Rejestruj )

Forum PHP.pl

 
Reply to this topicStart new topic
> [PHP][MYSQL] Wyświetlenie rekordów
Puzi
post 10.08.2008, 12:08:43
Post #1





Grupa: Zarejestrowani
Postów: 231
Pomógł: 17
Dołączył: 26.08.2007

Ostrzeżenie: (10%)
X----


Witam,
Mam taki problem. Posiadam w bazie danych tabelę o nazwie 'organizator' a w niej dane:
| id | rodzaj | data | gdzie |
-----------------------------------
| 1 | 1 | 2008-08-15 | krakow |
| 2 | 1 | 2008-08-16 | poznan |
| 3 | 3 | 2008-10-01 | gdansk |
| 4 | 2 | 2008-09-22 | krakow |
| 5 | 2 | 2008-09-26 | krakow |
| 6 | 1 | 2008-08-14 | gdynia |
| 7 | 3 | 2008-10-05 | gdansk |

I chcę wyświetlić rekordy według następujących kryterii:
-najpierw wyszukuje rekordy których data jest przyszłością i sortuje według daty rosnąco
-następnie grupuje je według typu
-i chcę wyświetlić tylko jedną grupę, która jest najwcześniej

Mam do tego taki skrypt:
  1. <?php
  2. $data = date("Y-m-d");
  3.  
  4. $zapytanie = "SELECT * FROM `organizator` WHERE `data` >= '{$data}' GROUP BY `rodzaj` ORDER BY `data` ASC";
  5. $wykonaj = mysql_query($zapytanie);
  6. while($wyswietl = mysql_fetch_row($wykonaj))
  7. {
  8. //wyświetlone dane
  9. }
  10. ?>


I w takim przypadku wyświetla mi wszystkie rekordy.
Jak zrobić, żeby wyświetliło tylko jedną grupę??

Prodszę o pomoc
Pozdrawiam
Go to the top of the page
+Quote Post
JoShiMa
post 10.08.2008, 12:16:04
Post #2





Grupa: Zarejestrowani
Postów: 1 374
Pomógł: 149
Dołączył: 1.03.2006

Ostrzeżenie: (0%)
-----


  1. SELECT *
  2. FROM `organizator` WHERE `data` >= '{$data}' AND typ=(SELECT typ FROM `organizator` WHERE ...)
  3. GROUP BY `rodzaj` ORDER BY `data` ASC


Tam gdzie trzy kropki musisz dać odpowiedni warunek, bo nie wiem co to znaczy 'najwcześniej'


--------------------
Go to the top of the page
+Quote Post
Puzi
post 10.08.2008, 12:36:46
Post #3





Grupa: Zarejestrowani
Postów: 231
Pomógł: 17
Dołączył: 26.08.2007

Ostrzeżenie: (10%)
X----


Najwcześniej czyli wyświetlić tą grupę, która będzie wykonana jako pierwsza patrząc na datę.

Zrobiłem takie zapytanie:
  1. SELECT * FROM `organizator` WHERE `data` >= '{$data}' AND typ=(SELECT typ FROM `organizator` WHERE `data` > '{$data}') GROUP BY `rodzaj` ORDER BY `data` ASC


i nie działa
Wywala błąd
Cytat
Warning: mysql_fetch_row(): supplied argument is not a valid MySQL result resource in


Może inaczej napiszę:
Chcę wyświetlić grupę rekordów według kolumny 'rodzaj' która będzie pierwsza wykonana patrząc na datę.

Ten post edytował Puzi 10.08.2008, 12:42:01
Go to the top of the page
+Quote Post
Kicok
post 10.08.2008, 13:52:05
Post #4





Grupa: Zarejestrowani
Postów: 1 033
Pomógł: 125
Dołączył: 17.09.2005
Skąd: Żywiec

Ostrzeżenie: (0%)
-----


  1. SELECT *
  2. FROM( SELECT * FROM `organizator` WHERE `data` >= '{$data}' ORDER BY `data` ASC ) `organizator`
  3. GROUP BY `rodzaj`


--------------------
"Sumienie mam czyste, bo nieużywane."
Go to the top of the page
+Quote Post
Puzi
post 10.08.2008, 14:53:33
Post #5





Grupa: Zarejestrowani
Postów: 231
Pomógł: 17
Dołączył: 26.08.2007

Ostrzeżenie: (10%)
X----


Terz nie ma błędu ale wyświetla po jednym rekordzie z każdego rodzaju... a ja chcę wyświetlić jedną całą grupę
Go to the top of the page
+Quote Post
JoShiMa
post 10.08.2008, 19:06:17
Post #6





Grupa: Zarejestrowani
Postów: 1 374
Pomógł: 149
Dołączył: 1.03.2006

Ostrzeżenie: (0%)
-----


A jesteś perien, że to zapytanie:
  1. SELECT typ FROM `organizator` WHERE `data` > '{$data}'

Zwraca Ci dokładnie jeden rekord najbliższego wydarzenia? Bo ja jestem pewna, że nie.


--------------------
Go to the top of the page
+Quote Post
Kicok
post 10.08.2008, 20:13:18
Post #7





Grupa: Zarejestrowani
Postów: 1 033
Pomógł: 125
Dołączył: 17.09.2005
Skąd: Żywiec

Ostrzeżenie: (0%)
-----


Cytat
Terz nie ma błędu ale wyświetla po jednym rekordzie z każdego rodzaju... a ja chcę wyświetlić jedną całą grupę

Napisałeś: "-następnie grupuje je według typu", a w MySQL GROUP BY `rodzaj` ma nieco inne działanie niż ty chciałbyś uzyskać ;]

Sprawdź to:
  1. SELECT *
  2. FROM `organizator` WHERE `rodzaj` = ( SELECT `rodzaj` FROM `organizator` WHERE `data` >= '{$data}' ORDER BY `data` ASC LIMIT 1 ) AND `data` >= '{$data}'
  3. ORDER BY `data` ASC


--------------------
"Sumienie mam czyste, bo nieużywane."
Go to the top of the page
+Quote Post

Reply to this topicStart new topic
1 Użytkowników czyta ten temat (1 Gości i 0 Anonimowych użytkowników)
0 Zarejestrowanych:

 



RSS Wersja Lo-Fi Aktualny czas: 19.07.2025 - 06:34