Avatar billede anri Novice
13. december 2013 - 11:45 Der er 3 kommentarer og
1 løsning

Rekrusiv query

Ok. Det her er nok noget man aldrig skal gøre på SQL serveren, men jeg vil lige have lidt eksternt input på det:

Jeg har en gruppe-struktur, hvor hver gruppe selv kan indeholde et vilkårligt andre grupper.

ID | Group | ParentID
1 | A | null
2 | B | null
3 | A1 | 1
4 | A2 | 1
5 | A11 | 3
6 | B1 | 2
....osv....

Hvis nu en bruger forspørger på ID 5 så vil jeg gerne have en kolonne der har en sammenlægning alle Parent-elementerne således at i ovenstående tilfælde vil den indeholde teksten "A/A1/A11".

Kan man gøre dette på en fornuftig måde på SQL serveren?
Avatar billede Slettet bruger
13. december 2013 - 12:59 #1
På Oracle kan det gøres med CONNECT BY. Prøv at se her for MS-SQL:
http://udonmez.wordpress.com/2011/07/01/ms-sql-with-keyword-oracle-start-with-connect-by-prior/
Avatar billede Syska Mester
16. december 2013 - 23:48 #2
Kig på: https://www.google.dk/?gws_rd=cr&ei=pYKvUvWYNoWN4wS1koGgCg#q=sql+parent+child+recursive&safe=off

Det burde give en masse ideer til hvordan det kan løses.

Lige specielt at tage den ud som en string er nok eneste del som ikke er specielt smart, men det kan løses ved en AGGREGATE funktion på en eller anden måde. Dog ikke noget jeg selv har prøvet, da det ikke rigtig har givet nogen mening for mig.

Men bottom line er at det godt og nemt kan lade sig gøre.
Avatar billede anri Novice
05. januar 2014 - 16:15 #3
Yeps buzz.
Den øverste bragte mig i mål..

Summa-sumarum; SQL serveren kan sagtens gøre det, og det performer også fint.
Avatar billede Syska Mester
06. januar 2014 - 09:46 #4
Super.

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