AGB  ·  Datenschutz  ·  Impressum  







Anmelden
Nützliche Links
Registrieren
Zurück Delphi-PRAXiS Programmierung allgemein Datenbanken Delphi Problem mit distinct
Thema durchsuchen
Ansicht
Themen-Optionen

Problem mit distinct

Ein Thema von Rolf Rostig · begonnen am 10. Apr 2004 · letzter Beitrag vom 17. Apr 2004
Antwort Antwort
Seite 1 von 2  1 2      
Rolf Rostig

Registriert seit: 5. Mär 2003
Ort: Stade
117 Beiträge
 
Delphi 7 Professional
 
#1

Problem mit distinct

  Alt 10. Apr 2004, 21:51
Hallo,

ich habe eine FB-Tabelle mit den Feldern ID, RechNr, KundenNr, ArikelNr.
Leider mit doppelten Einträgen der Rechnr und KundenNr.
Nun soll nur die ID und RechNr ohne Duplikate ausgegeben werden.
Mit

select distinct RechNr, ID from tabelle geht es nicht.
Wer hat eine Idee?
Gruss
Rolf
  Mit Zitat antworten Zitat
grayfox

Registriert seit: 22. Jan 2003
Ort: Litschau
173 Beiträge
 
Delphi 4 Standard
 
#2

Re: Problem mit distinct

  Alt 10. Apr 2004, 22:10
hallo rolf!

rein aus dem bauch heraus würde ich es so versuchen:
select distinct RechNr, distinct ID from tabelle alle angaben ohne gewähr

mfg, stefan
  Mit Zitat antworten Zitat
Rolf Rostig

Registriert seit: 5. Mär 2003
Ort: Stade
117 Beiträge
 
Delphi 7 Professional
 
#3

Re: Problem mit distinct

  Alt 10. Apr 2004, 22:23
Hi Stefan,

leider nicht.
Gruss
Rolf
  Mit Zitat antworten Zitat
Chewie

Registriert seit: 10. Jun 2002
Ort: Deidesheim
2.886 Beiträge
 
Turbo Delphi für Win32
 
#4

Re: Problem mit distinct

  Alt 10. Apr 2004, 22:39
Vielleicht so:

SELECT (DISTINCT rechnr), (DISTINCT ID) FROM table Sorry, ist nur geraten
Martin Leim
Egal wie dumm man selbst ist, es gibt immer andere, die noch dümmer sind
  Mit Zitat antworten Zitat
Robert_G
(Gast)

n/a Beiträge
 
#5

Re: Problem mit distinct

  Alt 11. Apr 2004, 00:04
Dein Code ist doch vollkommen richtig.
Mit Distinct sorgst du dafür, dass jede Zeile nur einmal vorkommt. Es werden werden also keine doppelten Paare von RechNr & ID ausgegeben.

p.s.:
SELECT distinct RechNr, distinct ... ... tut irgendwie weh
  Mit Zitat antworten Zitat
Rolf Rostig

Registriert seit: 5. Mär 2003
Ort: Stade
117 Beiträge
 
Delphi 7 Professional
 
#6

Re: Problem mit distinct

  Alt 11. Apr 2004, 12:37
Habe ich auch gedacht.
Aber das Ergebnis siehe Bild.
Miniaturansicht angehängter Grafiken
ergebnis_175.gif  
Gruss
Rolf
  Mit Zitat antworten Zitat
Benutzerbild von Sharky
Sharky

Registriert seit: 29. Mai 2002
Ort: Frankfurt
8.252 Beiträge
 
Delphi 2006 Professional
 
#7

Re: Problem mit distinct

  Alt 11. Apr 2004, 12:45
Hai Rolf Rostig,

mit distinct wird doch nur verhindert das doppelte Einträge angezeit werden. in deiner Liste gibt es aber keine doppelten paare von RechNr, ID.

Wenn ich dich richtig verstehe möchtest Du ja eine Abfrage die alle RechNr anzeigt die genau einmal in der Tabelle vergeben sind oder?
Stephan B.
"Lasst den Gänsen ihre Füßchen"
  Mit Zitat antworten Zitat
Rolf Rostig

Registriert seit: 5. Mär 2003
Ort: Stade
117 Beiträge
 
Delphi 7 Professional
 
#8

Re: Problem mit distinct

  Alt 11. Apr 2004, 12:52
ja genau
Gruss
Rolf
  Mit Zitat antworten Zitat
MarkusB

Registriert seit: 3. Apr 2004
Ort: Hamburg
105 Beiträge
 
#9

Re: Problem mit distinct

  Alt 11. Apr 2004, 13:57
Hallo Rolf!

Ist das Feld "ID" auch der Primär-Key in Deiner Tabelle?

Wenn ja (was ich auch vermute), dann hat die Klausel "DISTINCT" keine Wirkung in Deiner Abfrage, weil "ID" schon per Definition eindeutig ist (es können keine doppelten Einträge von ID existieren). Deshalb können auch keine doppelten Paare von "RechNr" und "ID" vorkommen.

Wenn Du alle RechNr selektieren willst, die in deiner Tabelle nur genau einmal vorkommen, solltest Du die "GROUP BY" und "HAVING" Klausel verwenden.
Ich würde das etwa so machen:

SQL-Code:
select RechNr
from tabelle
group by RechNr
having count(*) = 1
Viele Grüße
Markus
  Mit Zitat antworten Zitat
Robert_G
(Gast)

n/a Beiträge
 
#10

Re: Problem mit distinct

  Alt 11. Apr 2004, 21:27
Zitat:
SQL-Code:
select RechNr
from tabelle
group by RechNr
having count(*) = 1
Markus, hast du dir genau überlegt, was der Code macht?
Du gruppierst nach RechNr. Da du nur RechNr auswählst entspricht es exakt einem...
SQL-Code:
SELECT Distinct RechNr
FROM tabelle
...oder...
SQL-Code:
SELECT RechNr
FROM tabelle
GROUP BY RechNr
Das zusätzlich Count(*) = 1 in der HAVING Clause erfordert doch nur unnötigerweise einen weiteren Durchlauf der Daten.
  Mit Zitat antworten Zitat
Antwort Antwort
Seite 1 von 2  1 2      


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 07:52 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