Pomoc - Szukaj - Użytkownicy - Kalendarz
Pełna wersja: SELECT, 2 kolumny z jednej
Forum PHP.pl > Forum > Bazy danych > MySQL
jajoo
Witam mam tabele jak na screenie poniżej, chciałbym zrobić select wyświetlający tabele 4 kolumn, ich zawartość będzie uzależniona od id_przedmiotu a wyświetlane będą dane z kolumny "ocena", czyli w pierwszej kolumnie wyświetlone zostanie 3, 2, 2 w drugiej 5, 3, 5 itd. Jedną kolumnę mogę wyświetlić poprzez
  1. SELECT o.ocena AS "J. polski" FROM oceny AS o WHERE (o.id_przedmiotu=1 AND o.id_ucznia=1)
dalej nie mogę ruszyć.
sazian
nie bardzo rozumiem
chodzi o SELECT ocena,id_przedmiotu questionmark.gif
jajoo
Nie, zobacz jakie wartości są w kolumnie id_przedmiotu, są 1,2,3,4 - jak id_przedmiotu jest 1 to ocene wpisuje do kolumny nr 1, jeśli 2 to do kolumny nr 2 jeśli 3 to do kolumny 3 itd tak jak poniżej:

Kolumna nr 1:
3
2
2


Kolumna nr 2:
5
3
5


Kolumna nr 3:
2
4
5


Kolumna nr 4:
5
2
4
bww
Wydaje mi się, iż w tym przypadku słowem klucz będzie pivot table. http://en.m.wikibooks.org/wiki/MySQL/Pivot_table
jajoo
Witam po małej przerwie wróciłem do swojego programu, otóż mam taką tabelę:


Chcę zrobić analogicznie do tego: (źródło: http://en.m.wikibooks.org/wiki/MySQL/Pivot_table)

Cytat
mysql> select * from exams;
+------+------+------+-------+
| pkey | name | exam | score |
+------+------+------+-------+
| 1 | Bob | 1 | 75 |
| 2 | Bob | 2 | 77 |
| 3 | Bob | 3 | 78 |
| 4 | Bob | 4 | 80 |
| 5 | Sue | 1 | 90 |
| 6 | Sue | 2 | 97 |
| 7 | Sue | 3 | 98 |
| 8 | Sue | 4 | 99 |
+------+------+------+-------+
8 rows in set (0.00 sec)

mysql> select name,
sum(score*(1-abs(sign(exam-1)))) as exam1,
sum(score*(1-abs(sign(exam-2)))) as exam2,
sum(score*(1-abs(sign(exam-3)))) as exam3,
sum(score*(1-abs(sign(exam-4)))) as exam4
from exams group by name;

+------+-------+-------+-------+-------+
| name | exam1 | exam2 | exam3 | exam4 |
+------+-------+-------+-------+-------+
| Bob | 75 | 77 | 78 | 80 |
| Sue | 90 | 97 | 98 | 99 |
+------+-------+-------+-------+-------+
2 rows in set (0.00 sec)


u mnie score to "ocena" a exam to "id_przedmiotu". Zatem mój kod:
Cytat
select
sum(ocena*(1-abs(sign(id_przedmiotu-1)))) as "Język polski",
sum(ocena*(1-abs(sign(id_przedmiotu-2)))) as "Matematyka",
sum(ocena*(1-abs(sign(id_przedmiotu-3)))) as "Historia",
sum(ocena*(1-abs(sign(id_przedmiotu-4)))) as "Informatyka"
from oceny group by id


Daje wynik:


Chciałbym żeby pola ocena były jako varchar, teraz są int, i chciałbym w ten sam sposób wyświetlić tabelę jak w przykładzie wyżej, tylko z tekstem typu "3, 4, 5, 3, 1, 5, 2" czyli zamiast liczb teksty.


********************************************************************

EDIT:

Grupowałem po id zamiast po id_ucznia

select
sum(ocena*(1-abs(sign(id_przedmiotu-1)))) as "Język polski",
sum(ocena*(1-abs(sign(id_przedmiotu-2)))) as "Matematyka",
sum(ocena*(1-abs(sign(id_przedmiotu-3)))) as "Biologia",
sum(ocena*(1-abs(sign(id_przedmiotu-4)))) as "Historia"
from oceny group by id_ucznia

Działa, teraz pytanie jak zrobić ten sam efekt ale przy zmianie typu pól "ocena" z int na varchar i wypełnienie tych pól znakami np. "aaa" "bbb" itd?
To jest wersja lo-fi głównej zawartości. Aby zobaczyć pełną wersję z większą zawartością, obrazkami i formatowaniem proszę kliknij tutaj.
Invision Power Board © 2001-2025 Invision Power Services, Inc.