AGB  ·  Datenschutz  ·  Impressum  







Anmelden
Nützliche Links
Registrieren
Zurück Delphi-PRAXiS Programmierung allgemein Datenbanken Datensätze gruppieren: Wie Feldwert nach Bedingung setzen?
Thema durchsuchen
Ansicht
Themen-Optionen

Datensätze gruppieren: Wie Feldwert nach Bedingung setzen?

Ein Thema von BlueStarHH · begonnen am 15. Jun 2022 · letzter Beitrag vom 15. Jun 2022
Antwort Antwort
BlueStarHH

Registriert seit: 28. Mär 2005
Ort: Hamburg
850 Beiträge
 
Delphi 11 Alexandria
 
#1

Datensätze gruppieren: Wie Feldwert nach Bedingung setzen?

  Alt 15. Jun 2022, 11:49
Datenbank: Firebird • Version: 3.x • Zugriff über: IBDAC
Hallo,

ich habe diese Tabelle:

Code:
Adressen
-----------------
ID      Integer
Aktiv   Bool
Firma   Varchar
Strasse Varchar
Ort     Varchar
...
Ich möchte nun alle mehrfach vorhandenen gleichen Adressen ermitteln. Dabei sollen gleiche Adressen zusammen gruppiert werden und mitsamt den mehrfach vorhandenen IDs ausgegeben werden. Das mache ich so:

Code:
select coalesce(Firma, '') as Firma, coalesce(Strasse, '') as Strasse, coalesce(Ort, ''), list(ID) as IDs, from Adressen
group by Firma, Strasse, Ort
having count(*) > 1
Das funktioniert. Nun möchte ich dazu aber zusätlzich das Feld "Aktiv" dazu ausgeben und zwar so:

Wenn alle Adressen einer Gruppe aktiv=true haben soll in der Spalte Aktiv true stehen.
Wenn alle Adressen einer Gruppe aktiv=false haben soll in der Spalte Aktiv false stehen.
Wenn bei den Adressen einer Gruppe aktiv unterschiedlich ist, soll in der Spalte Aktiv true stehen.

Wie mache ich das?
  Mit Zitat antworten Zitat
Benutzerbild von himitsu
himitsu

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

AW: Datensätze gruppieren: Wie Feldwert nach Bedingung setzen?

  Alt 15. Jun 2022, 12:03
Du willst dieses Felder zusammen ziehen, also brauchst du eine Aggregatfunktion.
https://firebirdsql.org/refdocs/lang...-aggrfunc.html

Hier würde ich es mal mit MAX(Aktiv) versuchen.
Oder notfalls dürfte auch LIST(DISTINCT Aktiv) gehen, also "True", "False" oder "False,True" (oder so).

Falls Diese keinen BOOL mögen, dann eben mal kurz nach INT oder VARCHAR konvertieren und anschließend wieder zurück.



PS: denkbar wäre auch alles True=True (Haken), alles False=False (leer) und gemischt=NULL (grau).
$2B or not $2B

Geändert von himitsu (15. Jun 2022 um 12:05 Uhr)
  Mit Zitat antworten Zitat
BlueStarHH

Registriert seit: 28. Mär 2005
Ort: Hamburg
850 Beiträge
 
Delphi 11 Alexandria
 
#3

AW: Datensätze gruppieren: Wie Feldwert nach Bedingung setzen?

  Alt 15. Jun 2022, 12:18
Hier würde ich es mal mit MAX(Aktiv) versuchen.
Danke, das wars!
  Mit Zitat antworten Zitat
Antwort Antwort


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:08 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