AGB  ·  Datenschutz  ·  Impressum  







Anmelden
Nützliche Links
Registrieren
Zurück Delphi-PRAXiS Programmierung allgemein Datenbanken Delphi Fast Report - Leerzeile einfügen bei fehlendem Datensatz
Thema durchsuchen
Ansicht
Themen-Optionen

Fast Report - Leerzeile einfügen bei fehlendem Datensatz

Ein Thema von Jens Hartmann · begonnen am 3. Dez 2014 · letzter Beitrag vom 5. Dez 2014
Antwort Antwort
Seite 1 von 2  1 2      
Benutzerbild von Jens Hartmann
Jens Hartmann

Registriert seit: 11. Jan 2009
Ort: Wilnsdorf
1.439 Beiträge
 
Delphi XE2 Professional
 
#1

AW: Fast Report - Leerzeile einfügen bei fehlendem Datensatz

  Alt 4. Dez 2014, 20:38
Wie vorgesehen
Angehängte Grafiken
Dateityp: jpg Abfrage.JPG (16,4 KB, 6x aufgerufen)
Jens Hartmann
Das Leben selber ist zu kurz, also nutze jeden Tag wie er kommt.
  Mit Zitat antworten Zitat
Benutzerbild von himitsu
himitsu

Registriert seit: 11. Okt 2003
Ort: Elbflorenz
44.583 Beiträge
 
Delphi 12 Athens
 
#2

AW: Fast Report - Leerzeile einfügen bei fehlendem Datensatz

  Alt 4. Dez 2014, 20:40


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.
Ein Therapeut entspricht 1024 Gigapeut.
  Mit Zitat antworten Zitat
Benutzerbild von Jens Hartmann
Jens Hartmann

Registriert seit: 11. Jan 2009
Ort: Wilnsdorf
1.439 Beiträge
 
Delphi XE2 Professional
 
#3

AW: Fast Report - Leerzeile einfügen bei fehlendem Datensatz

  Alt 4. Dez 2014, 20:43
Ja, genau. So sitze ich aktuell auch hier.
Jens Hartmann
Das Leben selber ist zu kurz, also nutze jeden Tag wie er kommt.
  Mit Zitat antworten Zitat
Benutzerbild von himitsu
himitsu

Registriert seit: 11. Okt 2003
Ort: Elbflorenz
44.583 Beiträge
 
Delphi 12 Athens
 
#4

AW: Fast Report - Leerzeile einfügen bei fehlendem Datensatz

  Alt 4. Dez 2014, 20:47
Ein Bug im LEFT JOIN?

[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
Ein Therapeut entspricht 1024 Gigapeut.

Geändert von himitsu ( 4. Dez 2014 um 20:55 Uhr)
  Mit Zitat antworten Zitat
Benutzerbild von Jens Hartmann
Jens Hartmann

Registriert seit: 11. Jan 2009
Ort: Wilnsdorf
1.439 Beiträge
 
Delphi XE2 Professional
 
#5

AW: Fast Report - Leerzeile einfügen bei fehlendem Datensatz

  Alt 4. Dez 2014, 20:56
Ändere ich das ganze in einen RIGHT JOIN sieht es aus wie im Anhang 1

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
ZahlerEMA right join MGV_EMA Pass ich die Abfrage wieder an Rechte/Linke Tabelle wieder so...

MGV_EMA right join ZahlerEMA on MGV_EMA
Angehängte Grafiken
Dateityp: jpg Abfrage.JPG (23,2 KB, 6x aufgerufen)
Dateityp: jpg Abfrage_2.JPG (22,4 KB, 7x aufgerufen)
Jens Hartmann
Das Leben selber ist zu kurz, also nutze jeden Tag wie er kommt.
  Mit Zitat antworten Zitat
Benutzerbild von Sir Rufo
Sir Rufo

Registriert seit: 5. Jan 2005
Ort: Stadthagen
9.454 Beiträge
 
Delphi 10 Seattle Enterprise
 
#6

AW: Fast Report - Leerzeile einfügen bei fehlendem Datensatz

  Alt 4. Dez 2014, 21:23
Preisfrage: Was macht ein WHERE in einem SQL-Statement?

Wer das beantworten kann, weiß auch warum das Ergebnis so aussieht.

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
Kaum macht man's richtig - schon funktioniert's
Zertifikat: Sir Rufo (Fingerprint: ‎ea 0a 4c 14 0d b6 3a a4 c1 c5 b9 dc 90 9d f0 e9 de 13 da 60)

Geändert von Sir Rufo ( 4. Dez 2014 um 21:32 Uhr)
  Mit Zitat antworten Zitat
Benutzerbild von Jens Hartmann
Jens Hartmann

Registriert seit: 11. Jan 2009
Ort: Wilnsdorf
1.439 Beiträge
 
Delphi XE2 Professional
 
#7

AW: Fast Report - Leerzeile einfügen bei fehlendem Datensatz

  Alt 4. Dez 2014, 21:34
Zitat von Sir Rufo:
Preisfrage: Was macht ein WHERE in einem SQL-Statement?

Wer das beantworten kann, weiß auch warum das Ergebnis so aussieht.
Wer das beantworten kann, weiß das nicht.

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.
Angehängte Grafiken
Dateityp: jpg Abfrage.JPG (57,1 KB, 7x aufgerufen)
Jens Hartmann
Das Leben selber ist zu kurz, also nutze jeden Tag wie er kommt.
  Mit Zitat antworten Zitat
Benutzerbild von Sir Rufo
Sir Rufo

Registriert seit: 5. Jan 2005
Ort: Stadthagen
9.454 Beiträge
 
Delphi 10 Seattle Enterprise
 
#8

AW: Fast Report - Leerzeile einfügen bei fehlendem Datensatz

  Alt 4. Dez 2014, 21:43
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
Kaum macht man's richtig - schon funktioniert's
Zertifikat: Sir Rufo (Fingerprint: ‎ea 0a 4c 14 0d b6 3a a4 c1 c5 b9 dc 90 9d f0 e9 de 13 da 60)
  Mit Zitat antworten Zitat
Dejan Vu
(Gast)

n/a Beiträge
 
#9

AW: Fast Report - Leerzeile einfügen bei fehlendem Datensatz

  Alt 5. Dez 2014, 06:45
Damit wären in der rechten Spalte NULL-Werte. Aber in der rechten Spalte sind Werte, die es gar nicht gibt.
  Mit Zitat antworten Zitat
EarlyBird

Registriert seit: 29. Mär 2007
235 Beiträge
 
#10

AW: Fast Report - Leerzeile einfügen bei fehlendem Datensatz

  Alt 5. Dez 2014, 07:57
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;
  Mit Zitat antworten Zitat
Antwort Antwort
Seite 1 von 2  1 2      


Forumregeln

Es ist dir nicht erlaubt, neue Themen zu verfassen.
Es ist dir nicht erlaubt, auf Beiträge zu antworten.
Es ist dir nicht erlaubt, Anhänge hochzuladen.
Es ist dir nicht erlaubt, deine Beiträge zu bearbeiten.

BB-Code ist an.
Smileys sind an.
[IMG] Code ist an.
HTML-Code ist aus.
Trackbacks are an
Pingbacks are an
Refbacks are aus

Gehe zu:

Impressum · AGB · Datenschutz · Nach oben
Alle Zeitangaben in WEZ +1. Es ist jetzt 00:10 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-2025 by Thomas Breitkreuz