![]() |
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 |
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. |
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 |
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 |
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) |
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 |
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?
|
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 |
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 |
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 |
AW: SQL Abfrage mit Count
Wenn es also eine N zu 1 Beziehung ist, dann könnte es so funktionieren:
SQL-Code:
Frank
select
SNr.SNrArtNr , ArtMenge.ArtBestand , count(SNr.SNrArtNr) as Gesamt from SNr inner join ArtMenge on SNr.SNrArtNr = ArtMenge.ArtMengeNr where SNr.SNrStatus = true group by SNr.SNrArtNr , ArtMenge.ArtBestand having ArtMenge.ArtBestand <> count(SNr.SNrArtNr) |
AW: SQL Abfrage mit Count
SQL-Code:
Der Alias Gesamt ist innerhalb des Selects noch nicht bekannt, man kann erst in einem darüberliegenden Select darauf zugreifen.
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 <> count(SNr.SNrArtNr) /* den Alias Gesamt kann man hier nicht verwenden */ group by SNr.SNrArtNr;
SQL-Code:
Eventuell könnte auch sowas funktionieren (wird von jeder Datenbank etwas anders gehandhabt):
select * from (
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 <> count(SNr.SNrArtNr) group by SNr.SNrArtNr ) where Gesamt > 12345;
SQL-Code:
select A.SNrArtNr, ArtMenge.ArtBestand, A.Gesamt from (
select SNr.SNrArtNr, count(SNr.SNrArtNr) as Gesamt from SNr where SNr.SNrStatus = true ) A inner join ArtMenge on A.SNrArtNr = ArtMenge.ArtMengeNr where ArtMenge.ArtBestand <> A.Gesamt group by A.SNrArtNr, ArtMenge.ArtBestand |
AW: SQL Abfrage mit Count
SUUUPER!!! Das Script von Frank DataSpider hat genau das Ergebnis wie gewünscht gebracht:
SNrArtNr | ArtBestand | Gesamt --------------------------------------------------- 1041200 | 1 | 2 Das Script von Delphinarium bringt leider den Fehler: "Mit '*' ausgewählte Felder können nicht gruppiert werden" Ich danke euch allen für eure schnelle Hilfe! Besonders Frank hat heute die funktionierende Lösung gezeigt. :thumb: LG Euer Harry P.S. Super Forum hier :-D |
AW: SQL Abfrage mit Count
Ich fand den letzten Post von Uwe sehr gut. Hat er nicht funktioniert?
Zitat:
(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.) |
Alle Zeitangaben in WEZ +1. Es ist jetzt 22:02 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 by Thomas Breitkreuz