Delphi-PRAXiS
Seite 1 von 2  1 2      

Delphi-PRAXiS (https://www.delphipraxis.net/forum.php)
-   Datenbanken (https://www.delphipraxis.net/15-datenbanken/)
-   -   SQL Abfrage mit Count (https://www.delphipraxis.net/210437-sql-abfrage-mit-count.html)

HCB 26. Apr 2022 07:53

Datenbank: Access • Version: 2003 • Zugriff über: SQL

SQL Abfrage mit Count
 
Hallo, ich komme momentan nicht weiter. Folgender SQL code läuft:

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;

Ich möchte aber nur die Datensätze zeigen, wo Gesamt <> des Bestandes ist. Wenn ich folgenden Code nutze, läuft das Script nicht mehr:

select SNr.SNrArtNr, count(SNr.SNrArtNr) as Gesamt
from SNr
inner join ArtMenge on SNr.SNrArtNr = ArtMenge.ArtMengeNr
where SNr.SNrStatus = true and ArtMenge.ArtBestand <> Gesamt
group by SNr.SNrArtNr;

Kann mir jemand einen Tipp geben wie ich das hinbekomme? Das wäre sehr nett.

LG Harry

lxo 26. Apr 2022 07:56

AW: SQL Abfrage mit Count
 
Ich weiß nicht genau ob es das für Access gibt aber ich würde mal nach "window functions" suchen.
Das könnte dir helfen.

DeddyH 26. Apr 2022 08:16

AW: SQL Abfrage mit Count
 
Vielleicht so in der Art?
SQL-Code:
select X.* from(
  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) X
join ArtMenge on X.SNrArtNr = ArtMenge.ArtMengeNr
  and X.Gesamt <> ArtMenge.ArtBestand

HCB 26. Apr 2022 09:17

AW: SQL Abfrage mit Count
 
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

Uwe Raabe 26. Apr 2022 10:03

AW: SQL Abfrage mit Count
 
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)

HCB 26. Apr 2022 10:57

AW: SQL Abfrage mit Count
 
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

Uwe Raabe 26. Apr 2022 11:11

AW: SQL Abfrage mit Count
 
Erklär doch mal, was die Daten bedeuten und was du eigentlich zu erreichen versuchst. Ist der Inner Join eine 1:1 Beziehung?

HCB 26. Apr 2022 12:03

AW: SQL Abfrage mit Count
 
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

Uwe Raabe 26. Apr 2022 12:25

AW: SQL Abfrage mit Count
 
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

HCB 26. Apr 2022 12:55

AW: SQL Abfrage mit Count
 
@lxo
Nein, windows functions sind nicht kompatibel mit Access 2003. Schade.

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

LG Harry


Alle Zeitangaben in WEZ +1. Es ist jetzt 21:27 Uhr.
Seite 1 von 2  1 2      

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