![]() |
Datenbank: MySQL • Version: 5 • Zugriff über: direkt
Abhängigkeiten feststellen
Hallo Zusammen,
ich habe eine Anforderung, die meinen Horizont übersteigt. Ich hoffe, Ihr könnt mir helfen! Gegeben ist: BestllNr______Bestellpos____ArtikelNr 11111111________1_______081511111 11111111________2_______047115415 11111111________3_______054752215 22222222________1_______047115415 22222222________2_______054752215 33333333________1_______054752215 33333333________2_______047115415 44444444________1_______081511111 44444444________2_______047115415 44444444________3_______054752215 Also ich habe eine Tabelle mit BestellNr, Bestellposition Nr und ArtikelNr. Es können unterschiedliche viele Bestellpositionen in einer Bestellung sein. Die ArtikelNr können auf unterschiedlichen Bestellpositionen sein. Das Ziel ist, das ich Abhängigkeiten zwischen den Artikeln feststellen möchte. Das heißt, welche Kombinationen von Artikeln kommen in Bestellungen öfter vor usw. In dem oben benannten Beispiel kommen folgende Kombinationen vor 047115415, 054752215 , kommt 3 mal vor (11111 und 2222222 und 33333) 081511111, 047115415, 054752215 kommt 2 mal vor (1111, 44444) Ich habe keine leider keine Ahnung, wie ich das aus 6.000 Datensätzen herausbekommen soll. Kann mir jemand helfen? Vielen Dank Patrick |
AW: Abhängigkeiten feststellen
Kannst Du nicht einfach die Artikelliste vom tiefsten zum höchsten Wert durchlaufen und Dir jeweils die Anzahl Aufträge merken?
|
AW: Abhängigkeiten feststellen
Sowas hier?
Code:
SELECT A.ArtikelNr, B.ArtikelNr, COUNT(*) FROM Tabelle A
INNER JOIN Tabelle B ON A.BestllNr = B.BestllNr WHERE A.ArtikelNr > B.ArtikelNr /* damit Paare nicht doppelt und nicht mit sich selbst gepaar werden */ GROUP BY A.ArtikelNr, B.ArtikelNr ORDER BY A.ArtikelNr, COUNT(*) |
AW: Abhängigkeiten feststellen
Vielen Dank,
ich habe versucht, das Ganze auf 5 Bestellpositionen zu erweitern, bin damit aber nicht zurechtgekommen.
Delphi-Quellcode:
Ich habe ~6.000 Datensätze. Diese Query wirft aber 36.000 Datesätze zurück. Außerdem werden sogut wie keine Dopplungen angezeigt.
SELECT A.ArtikelNr, B.ArtikelNr, C.ArtikelNr, D.ArtikelNr, E.ArtikelNr, COUNT(*) as Anzahl FROM bewegung_2020 A
INNER JOIN bewegung_2020 B ON A.BestellNr = B.BestellNr INNER JOIN bewegung_2020 C ON A.BestellNr = C.BestellNr INNER JOIN bewegung_2020 D ON A.BestellNr = D.BestellNr INNER JOIN bewegung_2020 E ON A.BestellNr = E.BestellNr WHERE A.ArtikelNr > B.ArtikelNr AND B.ArtikelNr > C.ArtikelNr AND C.ArtikelNr > D.ArtikelNr AND D.ArtikelNr > E.ArtikelNr GROUP BY A.ArtikelNr, B.ArtikelNr, C.ArtikelNr, D.ArtikelNr, E.ArtikelNr ORDER BY A.ArtikelNr, B.artikelnr, C.artikelnr, D.artikelnr, E.artikelnr, Count(*) Sieht jemand was ich falsch mache? Ich suche die Möglichkeit, Artikelkombinationen aus Bestellungen zu finden und zu ranken. Vielen Dank Patrick |
AW: Abhängigkeiten feststellen
Zitat:
Code:
SELECT A.ArtikelNr, B.ArtikelNr, C.ArtikelNr, D.ArtikelNr, E.ArtikelNr, COUNT(*) as Anzahl FROM bewegung_2020 A
INNER JOIN bewegung_2020 B ON A.BestellNr = B.BestellNr INNER JOIN bewegung_2020 C ON A.BestellNr = C.BestellNr INNER JOIN bewegung_2020 D ON A.BestellNr = D.BestellNr INNER JOIN bewegung_2020 E ON A.BestellNr = E.BestellNr WHERE (A.ArtikelNr > B.ArtikelNr) AND (B.ArtikelNr > C.ArtikelNr OR C.ArtikelNr IS NULL) AND (C.ArtikelNr > D.ArtikelNr OR D.ArtikelNr IS NULL) AND (D.ArtikelNr > E.ArtikelNr OR E.ArtikelNr IS NULL) GROUP BY A.ArtikelNr, B.ArtikelNr, C.ArtikelNr, D.ArtikelNr, E.ArtikelNr ORDER BY A.ArtikelNr, B.artikelnr, C.artikelnr, D.artikelnr, E.artikelnr, Count(*) HAVING COUNT(*) > 1 |
Alle Zeitangaben in WEZ +1. Es ist jetzt 23:32 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