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, 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
 
#2

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
 
#3

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
 
#4

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
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 5. Dez 2014, 08:07
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:

SELECT * FROM MGV_EMA WHERE Anlagennummer = 1 2. Einen Record_Array oder eine Objekt erstellen und Query zuweisen

Delphi-Quellcode:
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
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.

Im Anhang mal ein Beispiel, von den aktuellen Dokumenten (Wir lösen das zur Zeit über Excel, jedoch manuell)
Angehängte Grafiken
Dateityp: jpg Beispiel Excel.JPG (44,1 KB, 5x aufgerufen)
Jens Hartmann
Das Leben selber ist zu kurz, also nutze jeden Tag wie er kommt.
  Mit Zitat antworten Zitat
Dejan Vu
(Gast)

n/a Beiträge
 
#6

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

  Alt 5. Dez 2014, 08:36
Wieso liest Du die Daten nicht einfach ein, kopierst sie in ein CDS, fügst Leerzeilen an den Stellen ein, die dir gefallen, und druckst das ganze vollkommen straightforward im FastReport aus? Das ist eine Sache von 5 Minuten und Du musst weder die Query noch deinen aktuellen Report anfassen...

Geändert von Dejan Vu ( 5. Dez 2014 um 09:14 Uhr)
  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
 
#7

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

  Alt 5. Dez 2014, 08:39
Wieso liest Du die Daten nicht einfach ein, kopierst sie in ein CDS, fügst Leerzeilen an den Stellen ein, die dir gefallen, und druckst das ganze vollkommen straightforward im FastReport aus? Das ist eine Sache von 5 Minuten und Du musst weder die Query noch deinen aktuellen Report anfassen?
Bitte nicht, diese Vorgehensweise (PreProcessing in der Anwendung) hatte ich schon vorgeschlagen (vor allem weil mit Access gearbeitet wird)
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
Benutzerbild von dataspider
dataspider

Registriert seit: 9. Nov 2003
Ort: 04539 Groitzsch
1.361 Beiträge
 
Delphi 11 Alexandria
 
#8

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

  Alt 5. Dez 2014, 08:58
Ich habe mal schnell in Fastreport einen Report mit Lückenanzeige gemacht (siehe Anhang).
Ist auch relativ wenig Arbeit, man muss nur:

zum MasterData ein Child machen...
Die Daten ins Child...
Die Lückentexte auf MasterData
Und im MasterData PrinChildIfInvisible auf True setzen.

Code:
Var
  LetzteNummer: Integer;                                            
  AnzahlLuecken: Integer;                                            
   
procedure frxReport1OnStartReport(Sender: TfrxComponent);
begin
  LetzteNummer := 0;                                    
end;

procedure LabelLueckeOnBeforePrint(Sender: TfrxComponent);
begin
  LabelLuecke.Text := InttoStr(AnzahlLuecken) + ' fehlende Nummern';                                                      
end;

procedure MasterData1OnBeforePrint(Sender: TfrxComponent);
begin
  AnzahlLuecken := <frxDBDataset1."Nummer"> - 1 - LetzteNummer;
  LetzteNummer := <frxDBDataset1."Nummer">;                                        
  BandData.Visible := False;                                  
  if AnzahlLuecken > 0 then
    BandData.Visible := True;
end;

begin

end.
Ich verlagere zwar auch gern alles auf die Datenebene, aber das hier kann man durchaus im Report lösen.

Frank
Angehängte Grafiken
Dateityp: jpg fastreport.jpg (25,2 KB, 5x aufgerufen)
Frank Reim
  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, 09:17
Bitte nicht, diese Vorgehensweise ..hatte ich schon vorgeschlagen...
Weil man Niemanden zu seinem Glück zwingen sollte? Die vorgehensweise von Dataspider ist mindestens genauso simpel, wenn man schon mal mit FR Scripten gearbeitet hat.

Na, ok. Ich halte mich raus.
  Mit Zitat antworten Zitat
Benutzerbild von Jens Hartmann
Jens Hartmann

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

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

  Alt 5. Dez 2014, 10:22
Zitat von dataspider:

Ich habe mal schnell in Fastreport einen Report mit Lückenanzeige gemacht (siehe Anhang).
Ist auch relativ wenig Arbeit, man muss nur:

zum MasterData ein Child machen...
Die Daten ins Child...
Die Lückentexte auf MasterData
Und im MasterData PrinChildIfInvisible auf True setzen.

markieren Code:
Var
LetzteNummer: Integer;
AnzahlLuecken: Integer;

procedure frxReport1OnStartReport(Sender: TfrxComponent);
begin
LetzteNummer := 0;
end;

procedure LabelLueckeOnBeforePrint(Sender: TfrxComponent);
begin
LabelLuecke.Text := InttoStr(AnzahlLuecken) + ' fehlende Nummern';
end;

procedure MasterData1OnBeforePrint(Sender: TfrxComponent);
begin
AnzahlLuecken := <frxDBDataset1."Nummer"> - 1 - LetzteNummer;
LetzteNummer := <frxDBDataset1."Nummer">;
BandData.Visible := False;
if AnzahlLuecken > 0 then
BandData.Visible := True;
end;

begin

end.
Ich verlagere zwar auch gern alles auf die Datenebene, aber das hier kann man durchaus im Report lösen.

Frank
Das funktioniert. Und ich denke, dem Aufwand gerecht. Keine Abhängigkeit von den Anzahl der Meldergruppen und optisch genau das was ich wollte.

Danke schon mal und Gruß Jens
Angehängte Grafiken
Dateityp: jpg Report.JPG (77,5 KB, 5x aufgerufen)
Jens Hartmann
Das Leben selber ist zu kurz, also nutze jeden Tag wie er kommt.
  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 08:37 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