AGB  ·  Datenschutz  ·  Impressum  







Anmelden
Nützliche Links
Registrieren
Zurück Delphi-PRAXiS Programmierung allgemein Datenbanken Anzahl der Datensatze count(*)
Thema durchsuchen
Ansicht
Themen-Optionen

Anzahl der Datensatze count(*)

Ein Thema von bernhard_LA · begonnen am 18. Aug 2015 · letzter Beitrag vom 18. Aug 2015
Antwort Antwort
bernhard_LA

Registriert seit: 8. Jun 2009
Ort: Bayern
1.123 Beiträge
 
Delphi 11 Alexandria
 
#1

Anzahl der Datensatze count(*)

  Alt 18. Aug 2015, 07:54
Datenbank: MSSQL • Version: ADO • Zugriff über: 2012
wie lautet das SQL Statement


 
Name FeldA FeldB FeldC
X ----- X --------
X
X
Y ----- Y
Y ----- Y
Z
W


um aus obiger Tabelle für alle Namen die Anzahl der Records auszugeben bei denen
dieser Name entweder im Feld A .... Feld C steht

also

 
Name AnzahlGefunden
X 1
Y 2
Z 0
W 0
o
  Mit Zitat antworten Zitat
Benutzerbild von rapante
rapante

Registriert seit: 3. Jun 2009
Ort: OPR
171 Beiträge
 
Delphi XE2 Professional
 
#2

AW: Anzahl der Datensatze count(*)

  Alt 18. Aug 2015, 08:07
So müsste es gehen:
Code:
SELECT name, COUNT(*) FROM table1 WHERE (name = FeldA) or (name = FeldB) or (name = FeldC) GROUP BY name;
  Mit Zitat antworten Zitat
Benutzerbild von Uwe Raabe
Uwe Raabe
Online

Registriert seit: 20. Jan 2006
Ort: Lübbecke
11.009 Beiträge
 
Delphi 12 Athens
 
#3

AW: Anzahl der Datensatze count(*)

  Alt 18. Aug 2015, 08:12
So müsste es gehen:
Code:
SELECT name, COUNT(*) FROM table1 WHERE (name = FeldA) or (name = FeldB) or (name = FeldC) GROUP BY name;
Liefert nur die Werte für X und Y, aber nicht die für W und Z.
Uwe Raabe
Certified Delphi Master Developer
Embarcadero MVP
Blog: The Art of Delphi Programming

Geändert von Uwe Raabe (18. Aug 2015 um 08:23 Uhr)
  Mit Zitat antworten Zitat
Benutzerbild von Uwe Raabe
Uwe Raabe
Online

Registriert seit: 20. Jan 2006
Ort: Lübbecke
11.009 Beiträge
 
Delphi 12 Athens
 
#4

AW: Anzahl der Datensatze count(*)

  Alt 18. Aug 2015, 08:29
So sollte es gehen (eventuell noch suboptimal):

SQL-Code:
SELECT a.Name, SUM(a.cnt)
FROM (
SELECT Name, Count(*) as cnt FROM table1 WHERE name in (FeldA, FeldB, FeldC) GROUP BY Name
UNION
SELECT Name, 0 as cnt FROM table_1 WHERE (FeldA is null or name <> FeldA) and (FeldB is null or name <> FeldB) and (FeldC is null or name <> FeldC) GROUP BY Name) a
GROUP BY a.Name
Uwe Raabe
Certified Delphi Master Developer
Embarcadero MVP
Blog: The Art of Delphi Programming
  Mit Zitat antworten Zitat
Benutzerbild von rapante
rapante

Registriert seit: 3. Jun 2009
Ort: OPR
171 Beiträge
 
Delphi XE2 Professional
 
#5

AW: Anzahl der Datensatze count(*)

  Alt 18. Aug 2015, 08:42
So müsste es gehen:
Code:
SELECT name, COUNT(*) FROM table1 WHERE (name = FeldA) or (name = FeldB) or (name = FeldC) GROUP BY name;
Liefert nur die Werte für X und Y, aber nicht die für W und Z.
Ahh, es ist einfach noch zu früh

Hier mal ein Versuch NACH dem ersten Kaffee mit einem Subselect:

Code:
SELECT DISTINCT t1.name,
       (SELECT COUNT(*) FROM table1 WHERE table1.name = t1.name AND (table1.name in (table1.FeldA, table1.FeldB, table1.FeldC))) AS cnt
FROM table1 AS t1
  Mit Zitat antworten Zitat
Benutzerbild von Uwe Raabe
Uwe Raabe
Online

Registriert seit: 20. Jan 2006
Ort: Lübbecke
11.009 Beiträge
 
Delphi 12 Athens
 
#6

AW: Anzahl der Datensatze count(*)

  Alt 18. Aug 2015, 08:45
Code:
SELECT DISTINCT t1.name,
       (SELECT COUNT(*) FROM table1 WHERE table1.name = t1.name AND (table1.name in (table1.FeldA, table1.FeldB, table1.FeldC))) AS cnt
FROM table1 AS t1
Sehr schön!
Uwe Raabe
Certified Delphi Master Developer
Embarcadero MVP
Blog: The Art of Delphi Programming
  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 23:10 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