Avatar billede chanfan Nybegynder
21. september 2000 - 13:00 Der er 4 kommentarer og
1 løsning

Select / Join

Jeg har 3 tabeller:
1: STAR_T med felterne ID, NAME, PICTURE.
2: MOVIE_T med felterne ID, TITLE, PICTURE.
3: MOVIE2STAR_T med felterne ID, MOVIE, STAR

I databasen er en masse skuespillere og film. Jeg bruger tabellen MOVIE2STAR_T til at
lave reference mellem en skuespiller og en film. MOVIE2STAR_T.MOVIE indeholder ID på filmen, og MOVIE2STAR_T.STAR indeholder ID på skuespilleren. Når jeg skal vise hvilke film en skuespiller har været med i søger jeg MOVIE2STAR_T igennem med skuespiller-ID\'en.
Men den kode jeg har lavet som består af flere SELECT-statements er blevet AL for langsom, så mit spørgsmål er; HVORDAN LAVER JEG DETTE I ÉN SELECT ???
Avatar billede erikjacobsen Ekspert
21. september 2000 - 13:11 #1
De film én skuespiller, nummer 117, har været med i

  select * from movie_t,movie2star_t where movie2star_t.stat=117 and movie2star_t.movie=movie_t.id

Eller alle skuespillere med alle film:

  select * from star_t,movie_t,movie2star_t where movie2start_t.star=star_t.id and movie2star_t.movie=movie_t.id

Og så bør du nok for overskuelighedens skyld skrive de præcise felter i stedet for *, f.eks:  movie_t.title, start_t.name
eller hvad du nu har brug for (med alle forbenhold for fejl)
Avatar billede lthrane Nybegynder
21. september 2000 - 13:14 #2
Skuespiller nummer = xxxxx

select movie_t.title from movie_t, star_t, movie2star_t
where movie_t.id = movie2star_t.movie and movie2star_t.star = xxxxxx

eller

select movie_t.title from movie_t where movie_t.id in (select movie from movie2star_t where movie2stat_t.star = xxxxxx)

Intet er testet....

lthrane
Avatar billede chanfan Nybegynder
21. september 2000 - 15:29 #3
erikjacobsen, dit svar virkede med det samme.
Jeg har derfor ikke prøvet dit lthrane om det virker...
Avatar billede erikjacobsen Ekspert
21. september 2000 - 15:34 #4
Jahh, men du har vel rettet min stavefejl, *g*
Avatar billede chanfan Nybegynder
21. september 2000 - 15:53 #5
Ja, selvom jeg ikke er SQL-haj kan jeg godt abstrahere for stavefejl! :-)
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
Kurser inden for grundlæggende programmering

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