AGB  ·  Datenschutz  ·  Impressum  







Anmelden
Nützliche Links
Registrieren
Zurück Delphi-PRAXiS Programmierung allgemein Datenbanken Delphi Pivot/Kreuztabellen in Firebird mit SQL erstellen
Thema durchsuchen
Ansicht
Themen-Optionen

Pivot/Kreuztabellen in Firebird mit SQL erstellen

Ein Thema von Chemiker · begonnen am 15. Apr 2009 · letzter Beitrag vom 22. Apr 2009
Antwort Antwort
Seite 1 von 3  1 23      
Benutzerbild von Chemiker
Chemiker

Registriert seit: 14. Aug 2005
1.859 Beiträge
 
Delphi 11 Alexandria
 
#1

Pivot/Kreuztabellen in Firebird mit SQL erstellen

  Alt 15. Apr 2009, 23:23
Datenbank: Firebird • Version: 2.0 • Zugriff über: FIBPlus
Hallo,

mit folgenden SQL-String werden die Daten in einem DBGrid angezeigt.

Delphi-Quellcode:
SQLString:= 'SELECT *FROM '+TabellenName+' where (MW_MSID LIKE :aMSId) and'+
              ' (MW_DatumUhrZeit between :aStartDatum and :aEndeDatum)';
Ausgabe:

MW_ID----MW_MSID---MW_DATUMUHRZEIT---------MW_MW
2609327--K01T1-------05.03.2008 00:00------------55,2
2609341--K01D1-------05.03.2008 00:00------------5046
2609355--K01T1-------05.03.2008 00:01------------162,7
2609369--K01D1-------05.03.2008 00:01------------5036,1

Die Ausgabe sollte aber so sein:

MW_DATUMUHRZEIT---K01T1--K01D1
05.03.2008 00:00------55,2----5046
05.03.2008 00:01------162,7---5036,1


Wie kann man mit Hilfe von SQL, die Ausgabe in einem DBGrid verändern?

Bis bald Chemiker

[edit=mkinzler]Threadtitel auf Wunsch des Te geändert Mfg, mkinzler[/edit]
wer gesund ist hat 1000 wünsche wer krank ist nur einen.
  Mit Zitat antworten Zitat
Benutzerbild von DeddyH
DeddyH

Registriert seit: 17. Sep 2006
Ort: Barchfeld
27.625 Beiträge
 
Delphi 12 Athens
 
#2

Re: DBGrid Spalten mit einem SQL –String anders anordnen

  Alt 15. Apr 2009, 23:39
Statt des * alle interessanten Spalten in der gewünschten Reihenfolge angeben.
Detlef
"Ich habe Angst vor dem Tag, an dem die Technologie unsere menschlichen Interaktionen übertrumpft. Die Welt wird eine Generation von Idioten bekommen." (Albert Einstein)
Dieser Tag ist längst gekommen
  Mit Zitat antworten Zitat
Benutzerbild von Chemiker
Chemiker

Registriert seit: 14. Aug 2005
1.859 Beiträge
 
Delphi 11 Alexandria
 
#3

Re: DBGrid Spalten mit einem SQL –String anders anordnen

  Alt 15. Apr 2009, 23:59
Hallo DeddyH,

das ist schon klar, aber so wird die Reihenfolge der Spalten nur verändert, aber die Anzeige bleibt.

Bis bald Chemiker
wer gesund ist hat 1000 wünsche wer krank ist nur einen.
  Mit Zitat antworten Zitat
mkinzler
(Moderator)

Registriert seit: 9. Dez 2005
Ort: Heilbronn
39.861 Beiträge
 
Delphi 11 Alexandria
 
#4

Re: DBGrid Spalten mit einem SQL –String anders anordnen

  Alt 16. Apr 2009, 06:30
Dann hast du die Reihenfolge im Grid so festgelegt ( Columns) und musst die Reihenfolge deshalb dort ändern
Markus Kinzler
  Mit Zitat antworten Zitat
Benutzerbild von Chemiker
Chemiker

Registriert seit: 14. Aug 2005
1.859 Beiträge
 
Delphi 11 Alexandria
 
#5

Re: DBGrid Spalten mit einem SQL –String anders anordnen

  Alt 16. Apr 2009, 07:34
Hallo mkinzler,

unter „Ausgabe:“ stehen in der 1 Reihe die Datenbankfelder und danach kommen die Werte.

Unter „Die Ausgabe sollte aber so sein:“ soll das Datum/Uhrzeit nur einmal stehen und unter den Datenbankwerten „K01T1“ und „K01D1“ „usw.“ sollen die Werte stehen die unter MW_MW normalerweise stehen.
Kurz gesagt es sollen Datenbank-Werte als Spaltenköpfe angezeigt werden.

Bis bald Chemiker
wer gesund ist hat 1000 wünsche wer krank ist nur einen.
  Mit Zitat antworten Zitat
mkinzler
(Moderator)

Registriert seit: 9. Dez 2005
Ort: Heilbronn
39.861 Beiträge
 
Delphi 11 Alexandria
 
#6

Re: DBGrid Spalten mit einem SQL –String anders anordnen

  Alt 16. Apr 2009, 07:42
Die Spaltennamen kann man auch bei den Columns einstellen. Mir ist aber nicht ganz klar, wie die Ausgabe aussehen soll bzw. ob ein Grid überhaupt die richtge Anzeigekomponente ist. Könntest du das gewünschte Aussehen etwas geanuer skizzieren?
Markus Kinzler
  Mit Zitat antworten Zitat
alzaimar
(Moderator)

Registriert seit: 6. Mai 2005
Ort: Berlin
4.956 Beiträge
 
Delphi 2007 Enterprise
 
#7

Re: DBGrid Spalten mit einem SQL –String anders anordnen

  Alt 16. Apr 2009, 07:50
Ah, Du möchtest eine Pivot-Darstellung deiner Daten.
So ungefähr könnte es klappen:
SQL-Code:
select MW_DATUMUHRZEIT,
       SUM (IIF (MW_MSID = 'K01T1', MW_MW,0)) as K01T1,
       SUM (IIF (MW_MSID = 'K01D1', MW_MW,0)) as K01D1
From Tabelle
where (MW_MSID LIKE :aMSId)
  and (MW_DatumUhrZeit between :aStartDatum and :aEndeDatum)
group by MW_DATUMUHRZEIT
"Wenn ist das Nunstruck git und Slotermeyer? Ja! Beiherhund das Oder die Flipperwaldt gersput!"
(Monty Python "Joke Warefare")
  Mit Zitat antworten Zitat
Benutzerbild von Chemiker
Chemiker

Registriert seit: 14. Aug 2005
1.859 Beiträge
 
Delphi 11 Alexandria
 
#8

Re: DBGrid Spalten mit einem SQL –String anders anordnen

  Alt 17. Apr 2009, 00:54
Hallo alzaimar,

danke für den Hinweis.
Mit IBExpert hat es relativ schnell geklappt, aber als SQL-String habe ich doch rechte lange für die Umsetzung gebraucht.

So sieht die 1 Version jetzt aus, als String:

Delphi-Quellcode:
SQLString:= 'SELECT MW_DATUMUHRZEIT,'+
       ' SUM (IIF (MW_MSID = ' +'''K01T1''' +', MW_MW,0)) AS K01T1,'+
       ' SUM (IIF (MW_MSID = ' +'''K01D1''' +', MW_MW,0)) AS K01D1'+
       ' FROM mw_tabelle'+
       ' where (MW_MSID LIKE '+'''K01%'''+')'+
       ' and (MW_DATUMUHRZEIT between '+'''05.03.2008'''+' and '+'''06.03.2008'''+')'+
       'GROUP BY MW_DATUMUHRZEIT';
als große Fehlerquelle hat sich die richtige Anzahl an ’ und Leerzeichen an der richtigen Position herausgestellt, die Fehlermeldungen die dabei produziert werden, sind dabei wenig aussagekräftig.

So sieht das im IBExpert-SQL-Editor aus:

SQL-Code:
select MW_DATUMUHRZEIT,
       SUM (IIF (MW_MSID = 'K01T1', MW_MW,0)) as K01T1,
       SUM (IIF (MW_MSID = 'K01D1', MW_MW,0)) as K01D1
From mw_tabelle
where (MW_MSID LIKE 'K01%')
  and (MW_DatumUhrZeit between '05.03.2008and '06.03.2008')
group by MW_DATUMUHRZEIT
Es soll nun noch dynamischer werden, dass wird aber morgen in Angriff genommen.

Bis bald Chemiker
wer gesund ist hat 1000 wünsche wer krank ist nur einen.
  Mit Zitat antworten Zitat
nahpets
(Gast)

n/a Beiträge
 
#9

Re: DBGrid Spalten mit einem SQL –String anders anordnen

  Alt 17. Apr 2009, 09:36
Hallo,

für meinen Editor habe ich mir mal dieses Script mit Pascalscript geschrieben.
Delphi-Quellcode:
program Sql2Source;
Var
        i : Integer;
begin
  Output.Clear;
  Output.Add('with qry.sql do begin');
  Output.Add(' clear;');
  for i := 0 to Editor.Count - 1 do begin
    Output.Add(' Add(''' + AnsiReplaceText(Editor[i],'''','''''') + ''');');
  end;
  Output.Add('end;');
  Log.Clear;
  Log.Add('SQLString := '''' ');
  for i := 0 to Editor.Count - 1 do begin
    Log.Add(' + ''' + AnsiReplaceText(Editor[i],'''','''''') + ' ''');
  end;
  Log[Log.Count - 1] := Log[Log.Count - 1] + ';';
end.
Da kommt dann dieses
Delphi-Quellcode:
with qry.sql do begin
  clear;
  Add('select MW_DATUMUHRZEIT,');
  Add(' SUM (IIF (MW_MSID = ''K01T1'', MW_MW,0)) as K01T1,');
  Add(' SUM (IIF (MW_MSID = ''K01D1'', MW_MW,0)) as K01D1');
  Add('From mw_tabelle');
  Add('where (MW_MSID LIKE ''K01%'')');
  Add(' and (MW_DatumUhrZeit between ''05.03.2008'' and ''06.03.2008'')');
  Add('group by MW_DATUMUHRZEIT');
end;
und jenes
Delphi-Quellcode:
SQLString := ''
 + 'select MW_DATUMUHRZEIT, '
 + ' SUM (IIF (MW_MSID = ''K01T1'', MW_MW,0)) as K01T1, '
 + ' SUM (IIF (MW_MSID = ''K01D1'', MW_MW,0)) as K01D1 '
 + 'From mw_tabelle '
 + 'where (MW_MSID LIKE ''K01%'') '
 + ' and (MW_DatumUhrZeit between ''05.03.2008'' and ''06.03.2008'') '
 + 'group by MW_DATUMUHRZEIT ';
heraus und das leidige '-Thema ist erledigt. Eventuell kannst Du ja damit was anfangen und Dir ein kleines Delphiprogrämmelchen schreiben, das aus einem SQL den passenden Quelltext bastelt. Sollte mit wenig Aufwand zu realisieren sein und hilft Stunden bei der Fehlersuche zu sparen. Meine SQL's werden in der entsprechenden Datenbankoberfläche erstellt und getestet und dann durch das Script gejagt und fertig ist.

Editor ist das Eingabefeld (TSynEdit) des Editors, Output und Log sind Ausgabefelder (ebenfalls TSynEdit), die als TStrings ans Script übergeben werden. Mit drei TMemos (und 'nem Dutzend zusätzlicher Quelltextzeilen) sollte das in ein paar Minuten zu realisieren sein.
  Mit Zitat antworten Zitat
Benutzerbild von Chemiker
Chemiker

Registriert seit: 14. Aug 2005
1.859 Beiträge
 
Delphi 11 Alexandria
 
#10

Re: DBGrid Spalten mit einem SQL –String anders anordnen

  Alt 17. Apr 2009, 19:16
Hallo nahpets,

keine schlechte Idee.

Die TSynEdit’s kann man durch TMemo’s ersetzen?

Bis bald Chemiker
wer gesund ist hat 1000 wünsche wer krank ist nur einen.
  Mit Zitat antworten Zitat
Antwort Antwort
Seite 1 von 3  1 23      


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 11:33 Uhr.
Powered by vBulletin® Copyright ©2000 - 2024, Jelsoft Enterprises Ltd.
LinkBacks Enabled by vBSEO © 2011, Crawlability, Inc.
Delphi-PRAXiS (c) 2002 - 2023 by Daniel R. Wolf, 2024 by Thomas Breitkreuz