AGB  ·  Datenschutz  ·  Impressum  







Anmelden
Nützliche Links
Registrieren
Zurück Delphi-PRAXiS Programmierung allgemein Datenbanken Delphi SQL Abfrage (keine DS Doppelt) ?
Thema durchsuchen
Ansicht
Themen-Optionen

SQL Abfrage (keine DS Doppelt) ?

Ein Thema von Karstadt · begonnen am 11. Dez 2005 · letzter Beitrag vom 11. Dez 2005
Antwort Antwort
Karstadt

Registriert seit: 8. Nov 2005
788 Beiträge
 
#1

SQL Abfrage (keine DS Doppelt) ?

  Alt 11. Dez 2005, 13:27
Datenbank: MYSQL • Version: 4 • Zugriff über: ODBC; DBE
Hallo. Gibt es so eine abfrage?

Nr:
1
2
1
2
3
4
5
6
7

Wieviel unterschiedliche nummer existierten in diese Tabelle?

MFG
  Mit Zitat antworten Zitat
Benutzerbild von Jelly
Jelly

Registriert seit: 11. Apr 2003
Ort: Moestroff (Luxemburg)
3.741 Beiträge
 
Delphi 2007 Professional
 
#2

Re: SQL Abfrage (keine DS Doppelt) ?

  Alt 11. Dez 2005, 13:59
select distinct Nr from Tabelle Liefert dir schon mal die Liste der unterschiedlichen Nr.... Das ganze in eine View vwNr gepackt:
select count(Nr) as Anzahl from vwNr
  Mit Zitat antworten Zitat
omata

Registriert seit: 26. Aug 2004
Ort: Nebel auf Amrum
3.154 Beiträge
 
Delphi 7 Enterprise
 
#3

Re: SQL Abfrage (keine DS Doppelt) ?

  Alt 11. Dez 2005, 14:25
Moin,

Zitat von Jelly:
select count(Nr) as Anzahl from vwNr
das kann man aber auch mit einer einzigen Anweisung erledigen...

SQL-Code:
SELECT COUNT(*) AS anzahl
FROM Tabelle
GROUP BY nr
MfG
Thorsten
  Mit Zitat antworten Zitat
dfried

Registriert seit: 16. Aug 2005
486 Beiträge
 
#4

Re: SQL Abfrage (keine DS Doppelt) ?

  Alt 11. Dez 2005, 14:45
Folgende Anweisung bringt das richtige Ergebnis:

Select count(distinct id) from vwNr
  Mit Zitat antworten Zitat
omata

Registriert seit: 26. Aug 2004
Ort: Nebel auf Amrum
3.154 Beiträge
 
Delphi 7 Enterprise
 
#5

Re: SQL Abfrage (keine DS Doppelt) ?

  Alt 11. Dez 2005, 14:57
@dfried: Danke für den Hinweis.

Mein Beitrag war ja wohl völlig daneben. Sorry.

Zitat von dfried:
Select count(distinct id) from vwNr
Aber warum dann den View benutzen? Dann kann man doch auch alles in eine Anweisung packen bzw. das DISTINCT ist doch jetzt doppeltgemoppelt.

SELECT COUNT(DISTINCT id) FROM Tabelle MfG
Thorsten
  Mit Zitat antworten Zitat
dfried

Registriert seit: 16. Aug 2005
486 Beiträge
 
#6

Re: SQL Abfrage (keine DS Doppelt) ?

  Alt 11. Dez 2005, 15:37
Zitat von omata:
Aber warum dann den View benutzen? Dann kann man doch auch alles in eine Anweisung packen bzw. das DISTINCT ist doch jetzt doppeltgemoppelt.

SELECT COUNT(DISTINCT id) FROM Tabelle
Jo, sorry, das war "Cut&Paste", hab gar nicht nach dem Tabellennamen im ersten Beitrag geschaut, sondern einfach den erstbesten da dran kopiert...
  Mit Zitat antworten Zitat
Benutzerbild von Jelly
Jelly

Registriert seit: 11. Apr 2003
Ort: Moestroff (Luxemburg)
3.741 Beiträge
 
Delphi 2007 Professional
 
#7

Re: SQL Abfrage (keine DS Doppelt) ?

  Alt 11. Dez 2005, 16:37
Zitat von omata:
das kann man aber auch mit einer einzigen Anweisung erledigen...

SQL-Code:
SELECT COUNT(*) AS anzahl
FROM Tabelle
GROUP BY nr
Nee, das klappt nicht. Als Ergebnis kriegst du so eine ganze Tabelle geliefert, nicht jedoch die Gesamtzahl der Records.

dfried's Lösung hingegen scheint zu klappen. Soweit hatte ich nicht gedacht. Das erspart damit also das Erstellen der View.
  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 03:22 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