AGB  ·  Datenschutz  ·  Impressum  







Anmelden
Nützliche Links
Registrieren
Zurück Delphi-PRAXiS Programmierung allgemein Datenbanken Text Daten von Vertikal in Horizontal bringen (alles in einen Zeile)

Text Daten von Vertikal in Horizontal bringen (alles in einen Zeile)

Ein Thema von Dumpfbacke · begonnen am 1. Okt 2019 · letzter Beitrag vom 1. Okt 2019
Antwort Antwort
Dumpfbacke

Registriert seit: 10. Mär 2005
Ort: Mitten in Deutschland
244 Beiträge
 
Delphi 10.2 Tokyo Professional
 
#1

Text Daten von Vertikal in Horizontal bringen (alles in einen Zeile)

  Alt 1. Okt 2019, 08:20
Datenbank: Firebird • Version: V2.5 • Zugriff über: IBX
Hallo Leute,
ich möchte gerne die Daten welche in einer Tabelle untereinander stehen nebeneinander bekommen. Mit Beträgen ist das ja kein Problem (SUM) aber wie mache ich das mit Text ?

Beispiel

Tabelle1

Delphi-Quellcode:
Standort, Regal, Artikeltext
Raum_1, 1, Artikel 1
Raum_1, 2, Artikel 2
Raum_1, 3,
Raum_1, 4, Artikel 4
In Raum_1 Regal 3 ist nicht drin.

Dann dachte ich mir es sollte so funktionieren

Delphi-Quellcode:
Select Standort,Regal,
iif (Regal = '1', Artikeltext,NULL) as Regal_1,
iif (Regal = '2', Artikeltext,NULL) as Regal_2,
iif (Regal = '3', Artikeltext,NULL) as Regal_3,
iif (Regal = '4', Artikeltext,NULL) as Regal_4,
From ArtikelDaten
Where Artikeltext <> 'and Artikeltext is not NULL
Groub by Standort,Regal
Also Ergbis hätte ich dann gerne
Raum1,Artikel 1,Artikel 2,,Artikel 4

Leider kommt das hier raus
Raum1,Artikel1,NULL,NULL,NULL
Raum1,NULL,Artikel2,NULL,NULL
Raum1,NULL,NULL,NULL,Artiek4

Nun die große Frage : "Wie bekomme ich alles in einen Zeile ?

Tanja
Tanja
  Mit Zitat antworten Zitat
mkinzler
(Moderator)

Registriert seit: 9. Dez 2005
Ort: Heilbronn
39.447 Beiträge
 
Delphi 10.2 Tokyo Enterprise
 
#2

AW: Text Daten von Vertikal in Horizontal bringen (alles in einen Zeile)

  Alt 1. Okt 2019, 08:28
Nennt sich Pivot. Du musst die Daten natürlich "aggregieren":

SQL-Code:
Select
  Standort,Regal,
  MIN(iif (Regal = '1', Artikeltext,NULL)) as Regal_1,
  MIN(iif (Regal = '2', Artikeltext,NULL)) as Regal_2,
  MINiif (Regal = '3', Artikeltext,NULL)) as Regal_3,
  MIN(iif (Regal = '4', Artikeltext,NULL)) as Regal_4,
From
  ArtikelDaten
Where
  Artikeltext <> 'and Artikeltext is not NULL
Group by
  Standort,Regal
Markus Kinzler
  Mit Zitat antworten Zitat
Dumpfbacke

Registriert seit: 10. Mär 2005
Ort: Mitten in Deutschland
244 Beiträge
 
Delphi 10.2 Tokyo Professional
 
#3

AW: Text Daten von Vertikal in Horizontal bringen (alles in einen Zeile)

  Alt 1. Okt 2019, 09:05
Danke das war aber einfach Tanja
Tanja
  Mit Zitat antworten Zitat
jobo

Registriert seit: 29. Nov 2010
2.625 Beiträge
 
Delphi 2010 Enterprise
 
#4

AW: Text Daten von Vertikal in Horizontal bringen (alles in einen Zeile)

  Alt 1. Okt 2019, 09:18
Das Statement ist wirklich nicht schwierig, wenn man es einmal gesehen hat. Eher unhandlich bei mehreren Spalten. Schwer ist es eher für den Server, der bei großen Datenmengen dann gut zu kauen hat.
Vielleicht kommt das ja in der Version 4 von Firebird als echte, optimierte Pivotfunktion?
Gruß, Jo
  Mit Zitat antworten Zitat
Themen-Optionen Thema durchsuchen
Thema durchsuchen:

Erweiterte Suche
Ansicht

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