![]() |
AW: Fast Report - Leerzeile einfügen bei fehlendem Datensatz
:gruebel:
Beim LEFT JOIN ist die linke Tabelle (FROM) vollständig enthalten und die andere Tabelle wird angehängt. Es werden maximal mehr Datensätze (wenn das ON pro linkem Datensatz rechts mehrere Datensätze trifft), aber nicht weniger. |
AW: Fast Report - Leerzeile einfügen bei fehlendem Datensatz
Ja, genau. So sitze ich aktuell auch hier.
|
AW: Fast Report - Leerzeile einfügen bei fehlendem Datensatz
Ein Bug im LEFT JOIN? :shock:
[edit]
SQL-Code:
SELECT Meldergruppe, Adresse, Etage, Meldebereich
FROM MGV_EMA WHERE Anlagennummer = 325 UNION SELECT MG, NULL, NULL, NULL FROM ZahlerEMA WHERE MG <= (SELECT max(*) FROM MGV_EMA WHERE Anlagennummer = 325) AND NOT exists(SELECT true FROM MGV_EMA WHERE Anlagennummer = 325 AND Meldergruppe = ZahlerEMA.MG) ORDER BY Meldergruppe |
AW: Fast Report - Leerzeile einfügen bei fehlendem Datensatz
Liste der Anhänge anzeigen (Anzahl: 2)
Ändere ich das ganze in einen RIGHT JOIN sieht es aus wie im Anhang 1
SQL-Code:
SELECT ZahlerEMA.MG, MGV_EMA.Meldergruppe FROM ZahlerEMA right join MGV_EMA on MGV_EMA.Meldergruppe = ZahlerEMA.MG WHERE Anlagennummer = 325 ORDER BY ZahlerEMA.MG
SQL-Code:
Pass ich die Abfrage wieder an Rechte/Linke Tabelle wieder so...
ZahlerEMA right join MGV_EMA
SQL-Code:
MGV_EMA right join ZahlerEMA on MGV_EMA
|
AW: Fast Report - Leerzeile einfügen bei fehlendem Datensatz
Preisfrage: Was macht ein WHERE in einem SQL-Statement?
Wer das beantworten kann, weiß auch warum das Ergebnis so aussieht. :mrgreen: Ob das wohl besser wäre ;)
SQL-Code:
SELECT
ZahlerEMA.MG, MGV_EMA.Meldergruppe FROM ZahlerEMA left join MGV_EMA on MGV_EMA.Meldergruppe = ZahlerEMA.MG AND Anlagennummer = 325 ORDER BY ZahlerEMA.MG |
AW: Fast Report - Leerzeile einfügen bei fehlendem Datensatz
Liste der Anhänge anzeigen (Anzahl: 1)
Zitat:
Die "Anlagennummer" in der WHERE Klausel des SQL-Statement, ist nur dafür zuständig, das nur Meldergruppen von einer Anlage geladen werden. Soll heißen, in der Tabelle MGV_EMA sind viele Anlagen enthalten. Diese müssen natürlich gefiltert werden. |
AW: Fast Report - Leerzeile einfügen bei fehlendem Datensatz
Jetzt mal Denken einschalten:
Wenn in der Datentabelle eine Lücke gefunden wird, dann bekommst du durch den LEFT JOIN ja trotzdem eine Zeile, allerdings mit einem NULL Wert. Soweit verstanden? Preisfrage: Was steht denn dann wohl in dem Feld Anlagennummer? Etwa NULL? Und was macht dann das WHERE, womit du sagst, gib mir alles wo 325 drin steht? Erwartest du dann die Zeilen mit dem Wert NULL? Die filterst du damit schön wieder aus :lol: |
AW: Fast Report - Leerzeile einfügen bei fehlendem Datensatz
Damit wären in der rechten Spalte NULL-Werte. Aber in der rechten Spalte sind Werte, die es gar nicht gibt.
|
AW: Fast Report - Leerzeile einfügen bei fehlendem Datensatz
eventuell so:
Code:
SELECT MG.MG, MGV.MelderGruppe, MGV.Anlagennummer
FROM MG LEFT JOIN (select MelderGruppe, Anlagennummer from EMA_MGV where Anlagennummer =325) AS MGV ON MG.MG = MGV.MelderGruppe; |
AW: Fast Report - Leerzeile einfügen bei fehlendem Datensatz
Liste der Anhänge anzeigen (Anzahl: 1)
So nach längerem Nachdenken, Ja die "WHERE" Klausel schränkt das ganze ein. Allerdings funktioniert die "AND" Verknüpfung im JOIN auch nicht.
Das ganze mit der Hilfstabelle, ist eigentlich auch nicht der richtige Weg. Betrachte ich das ganze nämlich auf das Gesamtsystem, wäre die Umsetzung über eine Hilfstabelle wahrscheinlich nicht sinnvoll. Es gibt System, die verfügen nicht nur über 256/512 Meldergruppen, sondern sind frei Konfigurierbar von z.B. 1 - 99999. Somit wird das ganze wieder eine Formatierungsaufgabe. Mein aktueller Lösungsansatz (So sollte es vermutlich funktioniere) sieht folgendermaßen aus: 1. Abrage der zugehörigen Meldergruppen zu der entsprechenden Anlagennummer:
SQL-Code:
2. Einen Record_Array oder eine Objekt erstellen und Query zuweisen
SELECT * FROM MGV_EMA WHERE Anlagennummer = 1
Delphi-Quellcode:
Jetzt stellt sich mir halt nur die Frage, kann es wirklich so aufwendig sein, eine einzelne däml... Leerzeile in eine Reporttabelle einzufügen, wenn die Spalte (1) nicht fortlaufend nummeriert ist.
type
T_MGV_EMA = record MG: string; Name: string; end; ... var F_MGV_EMA : array of T_MGV_EMA ... //Query dem Record über Schleife zuweisen ... //Record prüfen und bearbeiten ... //Record einem tfrxUserDataSet zuweisen //Report erstellen Im Anhang mal ein Beispiel, von den aktuellen Dokumenten (Wir lösen das zur Zeit über Excel, jedoch manuell) |
Alle Zeitangaben in WEZ +1. Es ist jetzt 01:49 Uhr. |
Powered by vBulletin® Copyright ©2000 - 2025, Jelsoft Enterprises Ltd.
LinkBacks Enabled by vBSEO © 2011, Crawlability, Inc.
Delphi-PRAXiS (c) 2002 - 2023 by Daniel R. Wolf, 2024 by Thomas Breitkreuz