AGB  ·  Datenschutz  ·  Impressum  







Anmelden
Nützliche Links
Registrieren
Zurück Delphi-PRAXiS Programmierung allgemein Datenbanken Abhängigkeiten feststellen

Abhängigkeiten feststellen

Ein Thema von Ykcim · begonnen am 22. Mär 2021 · letzter Beitrag vom 22. Mär 2021
Antwort Antwort
Ykcim

Registriert seit: 29. Dez 2006
Ort: NRW
804 Beiträge
 
Delphi 10.4 Sydney
 
#1

Abhängigkeiten feststellen

  Alt 22. Mär 2021, 17:10
Datenbank: MySQL • Version: 5 • Zugriff über: direkt
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
Patrick
  Mit Zitat antworten Zitat
Benutzerbild von blawen
blawen

Registriert seit: 30. Nov 2003
Ort: Luterbach (CH)
654 Beiträge
 
Delphi 12 Athens
 
#2

AW: Abhängigkeiten feststellen

  Alt 22. Mär 2021, 17:19
Kannst Du nicht einfach die Artikelliste vom tiefsten zum höchsten Wert durchlaufen und Dir jeweils die Anzahl Aufträge merken?
Roland
  Mit Zitat antworten Zitat
Redeemer

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

AW: Abhängigkeiten feststellen

  Alt 22. Mär 2021, 18:45
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(*)
Janni
2005 PE, 2009 PA, XE2 PA
  Mit Zitat antworten Zitat
Ykcim

Registriert seit: 29. Dez 2006
Ort: NRW
804 Beiträge
 
Delphi 10.4 Sydney
 
#4

AW: Abhängigkeiten feststellen

  Alt 22. Mär 2021, 20:26
Vielen Dank,

ich habe versucht, das Ganze auf 5 Bestellpositionen zu erweitern, bin damit aber nicht zurechtgekommen.

Delphi-Quellcode:
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(*)
Ich habe ~6.000 Datensätze. Diese Query wirft aber 36.000 Datesätze zurück. Außerdem werden sogut wie keine Dopplungen angezeigt.

Sieht jemand was ich falsch mache?

Ich suche die Möglichkeit, Artikelkombinationen aus Bestellungen zu finden und zu ranken.

Vielen Dank
Patrick
Patrick
  Mit Zitat antworten Zitat
Redeemer

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

AW: Abhängigkeiten feststellen

  Alt 22. Mär 2021, 22:07
Vielen Dank,

ich habe versucht, das Ganze auf 5 Bestellpositionen zu erweitern, bin damit aber nicht zurechtgekommen.

Ich habe ~6.000 Datensätze. Diese Query wirft aber 36.000 Datesätze zurück. Außerdem werden sogut wie keine Dopplungen angezeigt.

Sieht jemand was ich falsch mache?
Dein Code findet ausschließlich Fünferkombinationen. Bestellungen, die keine 5 Positionen haben, fallen also komplett raus. So sucht man mindestens 2 Kombinationen:
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
Janni
2005 PE, 2009 PA, XE2 PA
  Mit Zitat antworten Zitat
Themen-Optionen Thema durchsuchen
Thema durchsuchen:

Erweiterte Suche
Ansicht

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:29 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