AGB  ·  Datenschutz  ·  Impressum  







Anmelden
Nützliche Links
Registrieren
Thema durchsuchen
Ansicht
Themen-Optionen

SQL Abfrage mit Count

Ein Thema von HCB · begonnen am 26. Apr 2022 · letzter Beitrag vom 26. Apr 2022
Antwort Antwort
HCB

Registriert seit: 12. Feb 2020
218 Beiträge
 
Delphi 12 Athens
 
#1

AW: SQL Abfrage mit Count

  Alt 26. Apr 2022, 09:17
Wow, danke für die schnelle Reaktion!
Leider bringt Deddys code die Fehlermeldung "Syntaxfehler in FROM-Klausel".
Kann aber nicht feststellen (da Anfänger) wo der Fehler liegt.

Fällt dem einen oder anderen auf was falsch ist?

LG Harry
  Mit Zitat antworten Zitat
Benutzerbild von Uwe Raabe
Uwe Raabe

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

AW: SQL Abfrage mit Count

  Alt 26. Apr 2022, 10:03
Keine Ahnung ob das auch für Access geht, aber ein Filter für Group-Werte geht in der Regel über HAVING:
SQL-Code:
select SNr.SNrArtNr, count(SNr.SNrArtNr) as Gesamt
from SNr
inner join ArtMenge on SNr.SNrArtNr = ArtMenge.ArtMengeNr
where SNr.SNrStatus = true
group by SNr.SNrArtNr
having ArtMenge.ArtBestand <> count(SNr.SNrArtNr)
Uwe Raabe
Certified Delphi Master Developer
Embarcadero MVP
Blog: The Art of Delphi Programming
  Mit Zitat antworten Zitat
HCB

Registriert seit: 12. Feb 2020
218 Beiträge
 
Delphi 12 Athens
 
#3

AW: SQL Abfrage mit Count

  Alt 26. Apr 2022, 10:57
Danke Uwe für Deine Unterstüzung.
Leider erhalte ich jetzt diese Meldung:

"Sie wollten eine Abfrage ausführen, die den angegebenen Ausdruck 'Not ArtMenge.ArtBestand=count(SNr.SNrArtNr)' nicht als Teil der Aggregatfunktion einschließt"

Was auch immer das bedeuten mag.

LG Harry
  Mit Zitat antworten Zitat
Benutzerbild von Uwe Raabe
Uwe Raabe

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

AW: SQL Abfrage mit Count

  Alt 26. Apr 2022, 11:11
Erklär doch mal, was die Daten bedeuten und was du eigentlich zu erreichen versuchst. Ist der Inner Join eine 1:1 Beziehung?
Uwe Raabe
Certified Delphi Master Developer
Embarcadero MVP
Blog: The Art of Delphi Programming
  Mit Zitat antworten Zitat
HCB

Registriert seit: 12. Feb 2020
218 Beiträge
 
Delphi 12 Athens
 
#5

AW: SQL Abfrage mit Count

  Alt 26. Apr 2022, 12:03
In der einen Tabelle (ArtMenge) steht der Bestand (ArtBestand) des Artikels (ArMengeNr).

In der zweiten Tabelle (SNr) stehen die Seriennummern des Artikels.
Hier ist die Verbindung über die Artikelnummer (SNrArtNr) und (ArtMengeNr).
Ob die Seriennummer noch frei ist, kann man über SNrStatus = true abfragen.

Jetzt will ich wissen, ob die freien Seriennummern mit dem Bestand (ArtBestand) eines Artikels übereinstimmt.

So kann ich prüfen, ob beim Bestand z.B. 5 St. auch 5 freie Seriennummern zur Verfügung stehen,
wenn nicht, soll mir angezeigt werden, bei welchen Artikeln eine Differenz besteht.

Danke für die Mithilfe.

LG Harry
  Mit Zitat antworten Zitat
Benutzerbild von Uwe Raabe
Uwe Raabe

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

AW: SQL Abfrage mit Count

  Alt 26. Apr 2022, 12:25
In dem Fall würde ich eine Variante des Vorschlags von Detlev versuchen:
SQL-Code:
SELECT ArtMenge.ArtMengeNr, ArtMenge.ArtBestand, X.AnzahlSerienNummer from ArtMenge
JOIN (
  SELECT SNr.SNrArtNr AS SArtNr, COUNT(SNr.SNrArtNr) AS AnzahlSerienNummer
  FROM SNr
  GROUP BY SNr.SNrArtNr
  ) X ON X.SArtNr = ArtMenge.ArtMengeNr
WHERE ArtMenge.ArtBestand <> X.AnzahlSerienNummer
Uwe Raabe
Certified Delphi Master Developer
Embarcadero MVP
Blog: The Art of Delphi Programming
  Mit Zitat antworten Zitat
HCB

Registriert seit: 12. Feb 2020
218 Beiträge
 
Delphi 12 Athens
 
#7

AW: SQL Abfrage mit Count

  Alt 26. Apr 2022, 12:55
@lxo
Nein, windows functions sind nicht kompatibel mit Access 2003. Schade.

Hat noch jemand einen Vorschlag? Würde mich sehr freuen.

LG Harry
  Mit Zitat antworten Zitat
Redeemer

Registriert seit: 19. Jan 2009
Ort: Kirchlinteln (LK Verden)
1.118 Beiträge
 
Delphi 2009 Professional
 
#8

AW: SQL Abfrage mit Count

  Alt 26. Apr 2022, 18:13
Ich fand den letzten Post von Uwe sehr gut. Hat er nicht funktioniert?

"Sie wollten eine Abfrage ausführen, die den angegebenen Ausdruck 'Not ArtMenge.ArtBestand=count(SNr.SNrArtNr)' nicht als Teil der Aggregatfunktion einschließt"
Bei Verwendung von GROUP BY muss jede Spalte, die nicht hinter GROUP BY angegeben wird, als Aggregat verwendet werden (irgendwann vor der Ausgabe eine Aggregatfunktion durchlaufen).
(Bei MySQL ist das nicht der Fall und führt nicht zu einem Fehler. Das Verhalten in dem Fall ist aber zufällig und absolut nicht intuitiv. Ich würde aber MySQL auch nicht als sinnvolles DBMS bezeichnen.)
Janni
2005 PE, 2009 PA, XE2 PA

Geändert von Redeemer (26. Apr 2022 um 18:15 Uhr)
  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 02:11 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