[gelöst] Frage zu Left Join
Verfasst: Mi 20. Jan 2016, 12:49
Hallo,
ich möchte gerne einer Tabelle "Monate" (mit den Monaten Januar bis Dezember) jeweils einen Datensatz zuordnen, bei dem der Monat des in dem Datensatz enthaltenen Datums mit dem Monat der Tabelle "Monate" übereinstimmt.
Tabelle "Monate":
ID_Monate | Monat
1 | Januar
2 | Februar
3 | März
4 | April
etc...
Tabelle "Mieter"
ID_Mieter | Name | Einzugsdatum
1 | Müller | 11.05.2012
2 | Meier | 11.01.1999
3 | Schmitt | 03.03.2012
etc...
(bitte entschuldigt die "Formatierung")
Es soll also dem Monat der Tabelle "Monate" der Name des Mieters zugeordnet werden, der im jeweiligen Monat eingezogen ist.
Dabei sollen alle Monate ausgegeben werden, auch dann, wenn kein Mieter eingezogen ist.
Ich habe versucht das mit LEFT JOIN zu machen:
SELECT "Monate"."ID_Monate", "Mieter"."Name" FROM "Monate" LEFT JOIN "Mieter" ON "Monate"."ID_Monate" = MONTH( "Mieter"."Einzugsdatum" )
Dazu erhalte ich dann die folgende Fehlermeldung:
SQL-Status: 37000
Fehler-Code: -64
not allowed in OUTER JOIN condition in statement [SELECT "Monate"."ID_Monate", "Mieter"."Name" FROM "Monate" LEFT JOIN "Mieter" ON "Monate"."ID_Monate" = MONTH( "Mieter"."Einzugsdatum" )]
Kann jemand sagen was ich verkehrt mache?
Viele Grüße,
EarlMobile
ich möchte gerne einer Tabelle "Monate" (mit den Monaten Januar bis Dezember) jeweils einen Datensatz zuordnen, bei dem der Monat des in dem Datensatz enthaltenen Datums mit dem Monat der Tabelle "Monate" übereinstimmt.
Tabelle "Monate":
ID_Monate | Monat
1 | Januar
2 | Februar
3 | März
4 | April
etc...
Tabelle "Mieter"
ID_Mieter | Name | Einzugsdatum
1 | Müller | 11.05.2012
2 | Meier | 11.01.1999
3 | Schmitt | 03.03.2012
etc...
(bitte entschuldigt die "Formatierung")
Es soll also dem Monat der Tabelle "Monate" der Name des Mieters zugeordnet werden, der im jeweiligen Monat eingezogen ist.
Dabei sollen alle Monate ausgegeben werden, auch dann, wenn kein Mieter eingezogen ist.
Ich habe versucht das mit LEFT JOIN zu machen:
SELECT "Monate"."ID_Monate", "Mieter"."Name" FROM "Monate" LEFT JOIN "Mieter" ON "Monate"."ID_Monate" = MONTH( "Mieter"."Einzugsdatum" )
Dazu erhalte ich dann die folgende Fehlermeldung:
SQL-Status: 37000
Fehler-Code: -64
not allowed in OUTER JOIN condition in statement [SELECT "Monate"."ID_Monate", "Mieter"."Name" FROM "Monate" LEFT JOIN "Mieter" ON "Monate"."ID_Monate" = MONTH( "Mieter"."Einzugsdatum" )]
Kann jemand sagen was ich verkehrt mache?
Viele Grüße,
EarlMobile