AGB  ·  Datenschutz  ·  Impressum  







Anmelden
Nützliche Links
Registrieren
Zurück Delphi-PRAXiS Programmierung allgemein Datenbanken Delphi SQL oder nicht SQL ...

SQL oder nicht SQL ...

Ein Thema von mschaefer · begonnen am 10. Jan 2007 · letzter Beitrag vom 19. Feb 2007
Antwort Antwort
Seite 1 von 3  1 23   
Benutzerbild von mschaefer
mschaefer

Registriert seit: 4. Feb 2003
Ort: Hannover
2.029 Beiträge
 
Delphi XE3 Enterprise
 
#1

SQL oder nicht SQL ...

  Alt 10. Jan 2007, 11:53
Datenbank: FB • Version: 1.5 • Zugriff über: ...
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
Martin Schaefer
  Mit Zitat antworten Zitat
s14

Registriert seit: 15. Mai 2003
Ort: München
251 Beiträge
 
Delphi 7 Architect
 
#2

Re: SQL oder nicht SQL ...

  Alt 10. Jan 2007, 11:57
Hallo, das müsste doch mit "DISTINCT" möglich sein?
  Mit Zitat antworten Zitat
smudo

Registriert seit: 6. Sep 2005
Ort: Cottbus
362 Beiträge
 
Delphi XE2 Professional
 
#3

Re: SQL oder nicht SQL ...

  Alt 10. Jan 2007, 11:58
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
  Mit Zitat antworten Zitat
Benutzerbild von mschaefer
mschaefer

Registriert seit: 4. Feb 2003
Ort: Hannover
2.029 Beiträge
 
Delphi XE3 Enterprise
 
#4

Re: SQL oder nicht SQL ...

  Alt 10. Jan 2007, 12:13
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
Martin Schaefer
  Mit Zitat antworten Zitat
s14

Registriert seit: 15. Mai 2003
Ort: München
251 Beiträge
 
Delphi 7 Architect
 
#5

Re: SQL oder nicht SQL ...

  Alt 10. Jan 2007, 12:13
Stimmt, einen hab ich aber noch

Damit das Ergebniss mit der Vorgabe übereinstimmt sollte:

select Min(Nr), Kennung, Felder verwendet werden.
  Mit Zitat antworten Zitat
Benutzerbild von mschaefer
mschaefer

Registriert seit: 4. Feb 2003
Ort: Hannover
2.029 Beiträge
 
Delphi XE3 Enterprise
 
#6

Re: SQL oder nicht SQL ...

  Alt 10. Jan 2007, 12:45
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:

   SELECT DISTINCT
            Kennung
   FROM MyTable
   GROUP BY Kennung
Grüße // Martin
Martin Schaefer
  Mit Zitat antworten Zitat
s14

Registriert seit: 15. Mai 2003
Ort: München
251 Beiträge
 
Delphi 7 Architect
 
#7

Re: SQL oder nicht SQL ...

  Alt 10. Jan 2007, 12:54
Ich habe die Tabelle mit Deinen Daten nachgebaut, _Test genannt und mit:

SQL-Code:
select Min(Nr) as Nr, Kennung, Felder
from _Test
group by Kennung, Felder
genau das Ergebnis, wie in Deinem ersten Post, erhalten.

Allerdings verwende ich einen MS SQL-Server, vielleicht liegt es daran?
  Mit Zitat antworten Zitat
Hansa

Registriert seit: 9. Jun 2002
Ort: Saarland
7.554 Beiträge
 
Delphi 8 Professional
 
#8

Re: SQL oder nicht SQL ...

  Alt 10. Jan 2007, 12:55
Geht das nicht mit DISTINCT ? 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.
Gruß
Hansa
  Mit Zitat antworten Zitat
Benutzerbild von mschaefer
mschaefer

Registriert seit: 4. Feb 2003
Ort: Hannover
2.029 Beiträge
 
Delphi XE3 Enterprise
 
#9

Re: SQL oder nicht SQL ...

  Alt 10. Jan 2007, 13:10
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 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
Martin Schaefer
  Mit Zitat antworten Zitat
Benutzerbild von mschaefer
mschaefer

Registriert seit: 4. Feb 2003
Ort: Hannover
2.029 Beiträge
 
Delphi XE3 Enterprise
 
#10

Re: SQL oder nicht SQL ...

  Alt 10. Jan 2007, 14:47
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:

SELECT PER GROUP TOP 5
              Kennung, Field_2, Field_3
    FROM MyTable
    GROUP BY Kennung
    ORDER BY Kennung, Field_2 desc
.. das gibt es leider nicht...

Grüße // Martin
Martin Schaefer
  Mit Zitat antworten Zitat
Antwort Antwort
Seite 1 von 3  1 23   

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 09:23 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