![]() |
Datenbank: FB • Version: 1.5 • Zugriff über: ...
SQL oder nicht SQL ...
Moin, moin,
habe ein Datenbankabfrageproblem wo ich derzeit kapitulieren muß. Es existiert eine Liste mit Kennungen: Nr Kennung Felder -------------------- 1 AAAAAA Feldnr 2 2 AAAAAA Feldnr 2 3 AAAAAA Feldnr 2 4 BBBBBB Feldnr 2 5 BBBBBB Feldnr 2 6 BBBBBB Feldnr 2 7 BBBBBB Feldnr 2 8 BBBBBB Feldnr 2 9 CCCCCC Feldnr 2 ich hätte gerne die Datensätze, bei denen sich die erste Spalte zur vorhergehenden ändert, also hier: Nr Kennung Felder -------------------- 1 AAAAAA Feldnr 2 4 BBBBBB Feldnr 2 9 CCCCCC Feldnr 2 ist das irgendwie mit SQL zu lösen? Grüße // Martin |
Re: SQL oder nicht SQL ...
Hallo, das müsste doch mit "DISTINCT" möglich sein?
|
Re: SQL oder nicht SQL ...
Das sollte mit Group und Max funktionieren.
Distinct geht nicht, da Nr sich ändert. Edit: Habs mal aufgeschrieben
SQL-Code:
select Max(Nr), Kennung, Felder
from KENNUNGEN group by Name, Felder |
Re: SQL oder nicht SQL ...
Ja DISTINCT filtert in allen Feldern identische Datensätze. Richtig ist, das dann nur eine Zeile bleibt. Leider sind das keine identischen Datensätze, sondern die weiteren Felder ändern sich eher beliebig.
Ok werde mal ein Group by mit Max ansetzen. Danke ! Grüße // Martin |
Re: SQL oder nicht SQL ...
Stimmt, einen hab ich aber noch :-)
Damit das Ergebniss mit der Vorgabe übereinstimmt sollte:
SQL-Code:
verwendet werden. :???:
select Min(Nr), Kennung, Felder
|
Re: SQL oder nicht SQL ...
Schade,
es ist leider kniffliger: Das Max und das Min wirken sich in der Gruppierung nicht aus. Ich müßte nach Max(Kennung) Gruppieren können. Das läßt das Group aber nicht zu..... Wenn ich nur nach der Kennung selektiere und das Distinct anwende dann habe ich die Datensäteze dich haben möchte, aber leider nicht die rechts folgenden Felder.
SQL-Code:
Grüße // MartinSELECT DISTINCT Kennung FROM MyTable GROUP BY Kennung |
Re: SQL oder nicht SQL ...
Ich habe die Tabelle mit Deinen Daten nachgebaut, _Test genannt und mit:
SQL-Code:
genau das Ergebnis, wie in Deinem ersten Post, erhalten.
select Min(Nr) as Nr, Kennung, Felder
from _Test group by Kennung, Felder Allerdings verwende ich einen MS SQL-Server, vielleicht liegt es daran? |
Re: SQL oder nicht SQL ...
Geht das nicht mit DISTINCT ? :shock: Brauche das (bisher) zwar nicht, aber ich denke, das ist für so was da ? Falls es wirklich nicht geht, dann denke mal über den Einsatz einer SP mit Rückgabewerten nach (darin käme dann das max ins Spiel). Dann eben diese Rückgabewerte ausgeben.
|
Re: SQL oder nicht SQL ...
Hallo
Wollte die Gruppierung auf die Kennung laufen lassen. Habe keine Datensatznr. in der Tabelle. War für mich oben im Beispiel eher als Zeilenzähler gedacht. Da liegt genau der Wurm. Das Max, Min funtkioniert auf einen numerischen Wert und meine Kennung war bis eben :mrgreen: nicht numerisch! Bei nicht numerischen Kennungen würde ich nur das Konvertieren in eine Nummer sehen. Dafür bräuchte man wieder eine Funktion. Es geht daher tatsächlich mit dem Group By und ich brauche nicht Hansa´s (nett mal wieder was von Dir zu hören) Allround-Keule SP. Danke Euch noch mal! Grüße // Martin |
Re: SQL oder nicht SQL ...
So jetzt hat die Aufgabenstellung gewechselt:
Jetzt brauche ich die ersten fünf Datensätze einer jeden Gruppe in der Datenmenge! Das war es dann wohl mit SQL und Group By. Ohne SP soll es wohl heute nicht sein....
SQL-Code:
.. das gibt es leider nicht...SELECT PER GROUP TOP 5 Kennung, Field_2, Field_3 FROM MyTable GROUP BY Kennung ORDER BY Kennung, Field_2 desc Grüße // Martin |
Alle Zeitangaben in WEZ +1. Es ist jetzt 14:09 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