❤️ Helfen Sie noch heute, unser LibreOffice Forum zu erhalten! ❤️
Unterstützen Sie das LibreOffice-Forum und helfen Sie uns, unser Ziel für 2025 zu erreichen!

🍀 Jeder Beitrag zählt – vielen Dank für Ihre Unterstützung!🍀
Mit Ihrer Spende sichern Sie den Fortbestand, den Ausbau und die laufenden Kosten dieses Forums. 🌱


❤️ DANKE >> << DANKE ❤️

>> Dank Ihrer Unterstützung -> Keine Werbung für alle registrierten LibreOffice-Forum User! <<
🤗 Als Dankeschön werden Sie im Forum als LO-SUPPORTER gekennzeichnet. 🤗

[gelöst] Frage zu Left Join

Base ermöglicht es Ihnen, Ihre Daten in einer Datenbank direkt mit LibreOffice zu bearbeiten.
Antworten
EarlMobile
Beiträge: 3
Registriert: Mi 20. Jan 2016, 11:39
Wohnort: Hamburg

[gelöst] Frage zu Left Join

Beitrag von EarlMobile » 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
Dateianhänge
Datenbank_Mieter.zip
(4.1 KiB) 147-mal heruntergeladen
Zuletzt geändert von EarlMobile am Mi 20. Jan 2016, 18:11, insgesamt 2-mal geändert.

EarlMobile
Beiträge: 3
Registriert: Mi 20. Jan 2016, 11:39
Wohnort: Hamburg

Re: Frage zu Left Join

Beitrag von EarlMobile » Mi 20. Jan 2016, 17:42

nikki hat geschrieben:versuche es mal mit INNER JOIN.
Hallo, danke für die Antwort,

INNER JOIN erzeugt keinen Fehler, aber damit werden von der Tabelle "Monate" nur die Einträge ausgegeben zu denen ein Eintrag in der Tabelle "Mieter" existiert.
Ich möchte aber gerne, dass alle Einträge von "Monat" ausgegeben werden. In der Spalte "Name" soll dann die entsprechende Zeile leer (oder NULL oder so etwas) sein.

Viele Grüße,

EarlMobile

F3K Total
* LO-Experte *
Beiträge: 2501
Registriert: So 10. Apr 2011, 10:10

Re: Frage zu Left Join

Beitrag von F3K Total » Mi 20. Jan 2016, 17:44

Hallo,
doch HSQL kann LEFT JOIN, hat aber Probleme in der Bedingung den Monat abzufragen, was die Fehlermeldung ja auch sagt.
Mit einer Unterabfrage, in der zunächst MONTH("Einzugsdatum") ermittelt wird, klappt es einwandfrei:

Code: Alles auswählen

SELECT
    "ID_Monate",
    "Name"
FROM
    "Monate"
LEFT JOIN
    (SELECT 
        "Name",
        MONTH( "Einzugsdatum" ) "Einzugsmonat"
    FROM
    "Mieter")
ON "ID_Monate" = "Einzugsmonat"
Gruß R
Windows 11: AOO, LO Linux Mint: AOO, LO

EarlMobile
Beiträge: 3
Registriert: Mi 20. Jan 2016, 11:39
Wohnort: Hamburg

Re: Frage zu Left Join

Beitrag von EarlMobile » Mi 20. Jan 2016, 18:02

F3K Total hat geschrieben:Hallo,
doch HSQL kann LEFT JOIN, hat aber Probleme in der Bedingung den Monat abzufragen, was die Fehlermeldung ja auch sagt.
Mit einer Unterabfrage, in der zunächst MONTH("Einzugsdatum") ermittelt wird, klappt es einwandfrei
Hallo R,

vielen Dank, so gehts, Danke für die schnelle Lösung!

Grüße, und einen schönen Abend,

EarlMobile


An alle, die das LibreOffice-Forum gern nutzen und unterstützen wollen:


Bitte helfen Sie uns mit 7 Euro pro Monat.
Durch Ihren Beitrag tragen Sie dazu bei, unsere laufenden Kosten für die kommenden Monate zu decken.
Unkompliziert per Kreditkarte oder PayPal.
Als ein kleines Dankeschön werden Sie im LO-Forum als SUPPORTER gekennzeichnet.



Antworten