Avatar billede moejensen Nybegynder
17. marts 2006 - 10:27 Der er 9 kommentarer og
1 løsning

group by

Hvordan får jeg tilføjet i følgende:

SELECT Call.escaleted, Call.LocalUserID, Call.StartTime, Call.CallID, Calltype1.ElementTitle, Calltype2.ElementTitle AS CallType2, Call.Seconds FROM Call INNER JOIN Calltype1 ON Call.Calltype1ID = Calltype1.ElementID LEFT OUTER JOIN Calltype2 ON Call.Calltype2ID = Calltype2.ElementID

Så resultatet bliver gruperet Calltype1.ElementTitle
Avatar billede fsconsult.dk Nybegynder
17. marts 2006 - 10:34 #1
mener du grupperet eller sorteret??

formålet med en group by er at kunne lave funktioner som COUNT, SUM, AVG m.m.
Avatar billede ldanielsen Nybegynder
17. marts 2006 - 10:47 #2
Ja, vi ved ikke hvad du vil ...
Avatar billede moejensen Nybegynder
17. marts 2006 - 10:50 #3
nåå ja det kan jeg godt se.

Jeg vil jo sådanset ha så jeg kun får hver forkomst for sig, og så med et antal af forkomster :-)
Avatar billede fsconsult.dk Nybegynder
17. marts 2006 - 10:57 #4
lyder mest som om du skal tilføje "ORDER BY Calltype1.ElementTitle", men er stadig ikke sikker på at jeg har forstået dig korrekt
Avatar billede moejensen Nybegynder
17. marts 2006 - 11:03 #5
jeg vil gerne ha dem samlet så Calltype1.ElementTitle, Calltype2.ElementTitle kun opstår en gang, og så står der bare hvor mange der er af hver.
Avatar billede ldanielsen Nybegynder
17. marts 2006 - 11:04 #6
Du vil altså have at dit dataset kun har unikke Calltype1.ElementTitle, ikke sandt

Så:

SELECT COUNT(*), Calltype1.ElementTitle
FROM Call INNER JOIN Calltype1
ON Call.Calltype1ID = Calltype1.ElementID
LEFT OUTER JOIN Calltype2
ON Call.Calltype2ID = Calltype2.ElementID
GROUP BY Calltype1.ElementTitle

Dette giver unikke Calltype1.ElementTitle, samt det antal gange de forekommer.

Men så mangler alle de andre kolonner jo, og spørgsmålet er hvad det er du vil have ud. Tilføjer du en koklonne mere til SELECT, så skal den også tilføjes GROUP BY.

Som fsconsult.dk siger skal du ellers bruge MAX, SUM, COUNT eller andet
Avatar billede moejensen Nybegynder
20. marts 2006 - 13:35 #7
har du noget bud på den her:

jeg vil gerne ha dem samlet så Calltype1.ElementTitle, Calltype2.ElementTitle kun opstår en gang, og så står der bare hvor mange der er af hver.

så jeg bare får antallet for hver af de forskellige kombinationer af calltype 1 og 2?
Avatar billede ldanielsen Nybegynder
21. marts 2006 - 06:35 #8
Prøv med:

SELECT COUNT(*), Calltype1.ElementTitle, Calltype2.ElementTitle
FROM Call INNER JOIN Calltype1
ON Call.Calltype1ID = Calltype1.ElementID
LEFT OUTER JOIN Calltype2
ON Call.Calltype2ID = Calltype2.ElementID
GROUP BY Calltype1.ElementTitle, Calltype2.ElementTitle
Avatar billede moejensen Nybegynder
07. maj 2006 - 16:09 #9
det virkede, laver du et svar
Avatar billede ldanielsen Nybegynder
08. maj 2006 - 10:03 #10
Svar
Avatar billede Ny bruger Nybegynder

Din løsning...

Tilladte BB-code-tags: [b]fed[/b] [i]kursiv[/i] [u]understreget[/u] Web- og emailadresser omdannes automatisk til links. Der sættes "nofollow" på alle links.

Loading billede Opret Preview
Kategori
Computerworld tilbyder specialiserede kurser i database-management

Log ind eller opret profil

Hov!

For at kunne deltage på Computerworld Eksperten skal du være logget ind.

Det er heldigvis nemt at oprette en bruger: Det tager to minutter og du kan vælge at bruge enten e-mail, Facebook eller Google som login.

Du kan også logge ind via nedenstående tjenester