Zum Inhalt springen
View in the app

A better way to browse. Learn more.

Fachinformatiker.de

A full-screen app on your home screen with push notifications, badges and more.

To install this app on iOS and iPadOS
  1. Tap the Share icon in Safari
  2. Scroll the menu and tap Add to Home Screen.
  3. Tap Add in the top-right corner.
To install this app on Android
  1. Tap the 3-dot menu (⋮) in the top-right corner of the browser.
  2. Tap Add to Home screen or Install app.
  3. Confirm by tapping Install.

Access Join in SQL Join "umwandeln"

Empfohlene Antworten

Veröffentlicht

hi

wir habe eine Datenbankanbindung per hsqldb und die SELECTS haben wir per Access Assistent erstellt. Ich blick bei den ganzen JOINS nicht durch, daher der Umweg über Access.

Aber leider ist dieser SELECT unter SQL nicht möglich, er sagt "Unexpected token Filmmedium." Und da diese ganzen INNER JOINS wirklich abenteuerlich aussehen, wollte ich fragen ob mir da nicht jemand helfen kann, das es auch unter sql geht ;)

Hier der SELECT:


SELECT Film.Name, Film.Jahr, Film.Inhalt, Film.Cover, FilmFormat.Format,

FilmGenre.Name, FilmMedium.Medium, FilmOrt.Ort FROM FilmOrt 

INNER JOIN (FilmMedium INNER JOIN (FilmGenre INNER JOIN 

(FilmFormat INNER JOIN Film ON FilmFormat.ID=Film.FormatID) ON 

FilmGenre.ID=Film.GenreID) 

ON FilmMedium.ID=Film.MediumID) ON FilmOrt.ID=Film.OrtID


SELECT Film.Name, Film.Jahr, Film.Inhalt, Film.Cover, FilmFormat.Format,

FilmGenre.Name, FilmMedium.Medium, FilmOrt.Ort FROM FilmOrt 

INNER JOIN (FilmMedium INNER JOIN (FilmGenre INNER JOIN 

(FilmFormat INNER JOIN Film ON FilmFormat.ID=Film.FormatID) ON 

FilmGenre.ID=Film.GenreID) 

ON FilmMedium.ID=Film.MediumID) ON FilmOrt.ID=Film.OrtID
Ich glaub, wenn du's per WHERE "", könnte es klappen, je nachdem, wie extrem diese ganzen Filmtabellen miteinander verstrickt sind...
SELECT Film.Name, Film.Jahr, Film.Inhalt, Film.Cover, FilmFormat.Format,

FilmGenre.Name, FilmMedium.Medium, FilmOrt.Ort FROM FilmOrt 

WHERE FilmFormat.ID=Film.FormatID AND FilmFormat.ID=Film.FormatID AND FilmGenre.ID=Film.GenreID AND FilmMedium.ID=Film.MediumID AND FilmOrt.ID=Film.Ort

SELECT Film.Name, Film.Jahr, Film.Inhalt, Film.Cover, FilmFormat.Format,

FilmGenre.Name, FilmMedium.Medium, FilmOrt.Ort FROM FilmOrt 

WHERE FilmFormat.ID=Film.FormatID AND FilmFormat.ID=Film.FormatID AND FilmGenre.ID=Film.GenreID AND FilmMedium.ID=Film.MediumID AND FilmOrt.ID=Film.Ort
wenn dann musst du aber hinterm FROM auf jeden fall noch die restlichen tabellen mit angeben
... FROM FilmOrt, FilmMedium, FilmGenre, FilmFormat, Film WHERE ...

SELECT Film.Name, Film.Jahr, Film.Inhalt, Film.Cover, FilmFormat.Format,

FilmGenre.Name, FilmMedium.Medium, FilmOrt.Ort

FROM FilmOrt

INNER JOIN Film ON FilmOrt.ID=Film.OrtID

INNER JOIN FilmMedium ON FilmMedium.ID=Film.MediumID

INNER JOIN FilmGenre ON FilmGenre.ID=Film.GenreID

INNER JOIN FilmFormat ON FilmFormat.ID=Film.FormatID

Gruß Jaraz

wenn dann musst du aber hinterm FROM auf jeden fall noch die restlichen tabellen mit angeben

... FROM FilmOrt, FilmMedium, FilmGenre, FilmFormat, Film WHERE ...

Ups....natürlich! :cool:

danke sowohl das "neue" INNER JOIN als auch das SELECT mit WHERE klappt gut.

Allerdings zeigt er kein Ergebnis an, obwohl die anderen Tabellen gefüllt sind!

Tabelle Film:


ID NAME         GENREID JAHR INHALT COVER  MEDIUMID ORTID FORMATID 

-- ------------ ------- ---- ------ ------ -------- ----- -------- 

0  Mein 1. Film 1            [null] [null] 1              1        

Tabelle Genre:

ID NAME    

-- ------- 

0  Action  

1  Komödie 

Tabelle Format:

ID FORMAT 

-- ------ 

0  DivX   

1  SVCD  
Tabelle Medium:

ID MEDIUM 

-- ------ 

0  DVD    

1  CD    

Tabelle Ort:

ID ORT     

-- ------- 

0  Küche   

1  Schrank 

Warum aber bleibt die Abfrage aus Film über die anderen Tabellen mittels INNER JOIN oder SELECT und WHERE leer?!

//Edit:

Ok Problem beseitigt!

Die OrtID war in der Tabelle Film nicht gefüllt ;) nun gehts!

danke! :uli

Archiv

Dieses Thema wurde archiviert und kann nicht mehr beantwortet werden.

Configure browser push notifications

Chrome (Android)
  1. Tap the lock icon next to the address bar.
  2. Tap Permissions → Notifications.
  3. Adjust your preference.
Chrome (Desktop)
  1. Click the padlock icon in the address bar.
  2. Select Site settings.
  3. Find Notifications and adjust your preference.