Rätsel: Vorschlag für einen sinnvollen Algorythmus gesucht.

Status
Nicht offen für weitere Antworten.
G

Guest

Gast
Hallo zusammen,

ich verwalte in einer Datenbank Kundendaten und Artikeldaten.
Darüber hinaus habe ich eine Tabelle mit den Spalten Kundennummer+Artikelnummer.

Ich möchte nun folgendes realisieren (auch wenn es nicht einleuchtend klingt):

Die Kombination (Kundennummer+Artikelnummer) darf nur EINMAL vorkommen.
Wenn der Kunde den gleichen Artikel erneut bestellt, soll ihm per Zufall ein anderer Artikel zugewiesen werden.
Diese neue Kombination darf natürlich auch nicht doppelt vorkommen ansonsten wird wieder zufällig ein
neuer Artikel vergeben und zwar solange bis eine neue Kombination entsteht. Erst die neue Kombination
wird dann in die Tabelle (Kundennummer+Artikelnummer) eingetragen.

Wörtlich gesagt heisst das, der Kunde kann den Artikel nur EINMAL erwerben und dann nie wieder.


Nun meine Grundsatzfrage:

Theoretisch müsste ich bei einer neuen Bestellung jeder Kundennummer eine Artikelnummer zuweisen
und dann prüfen ob diese Kombination schon vorhanden ist. Wenn nicht erfolgt ein EINTRAG in Tabelle wenn ja ERNEUTE Zuweisung und Prüfung.

Ich dachte hier an zwei Arrays. Eins mit den Daten aus den bestehende Aufträgen (Kundennummern+Artikelnummern)
und eins mit den neuen. Dann Prüfung....

Gehen wir exemplarisch von sagen wir mal 100 neuen und 1000 bestehenden Kombinationen aus.
Ich hätte somit eine 100*1000 = 100.000 Prüfungen vorzunehmen oder sogar mehr, wenn die Prüfung
unterbrochen werden muss, weil ein doppelter Eintrag gefunden wurde....

Wer hat einen Vorschlag um diesen Algorythmus zu vermeiden?

Vielen Dank!
 

P3AC3MAK3R

Top Contributor
Du schreibst ja, daß Du eine Datenbank (welche überhaupt?) verwendest. Das Problem sollte sich eigentlich auf SQL-Ebene leichter lösen lassen.
 

thomator

Bekanntes Mitglied
Oder Du schreibst Dir alle vorhandenen Kombinationen in eine HashMap und prüfst jeweils nur, ob das Ding darin schon existiert. Neu angelegte Kombis immer schön dazu (HashMap und Datenbank), HashMap im Speicher halten und die existierenden Kombis nur einmal beim Start reinladen. (oder so)
Dann hast Du maximal so viele Prüfungen, wie bereits Kombis vorhanden sind...
 
G

Guest

Gast
hallo,

es ist eine Access Datenbank.
Gibt es dafür eine Lösung auf SQL Ebene?

Viele Grüße
 

P3AC3MAK3R

Top Contributor
Eigentlich mußt Du ja nur per

Code:
select count(*) from kunde-artikel where kunde = x and artikel = y

prüfen, ob die Kombination bereits vorhanden ist, bevor Du einen Eintrag in der Kunde-Artikel-Tabelle vornimmst.

Wenn das der Fall ist, ermittelst Du eben zufällig eine neue Artikelnummer (vielleicht hilft dabei dieser Link weiter) und führst die Prüfung erneut durch.
 

NTB

Bekanntes Mitglied
Ich würde das nicht ganz von der Datenbank lösen lassen.
Thomators Vorschlag würde ich auch so umsetzen. Um eine neue Bestellung zu bearbeiten:
- alle Artikel des Kunden aus der Datenbank in eine Map laden
- zu bestellenden Artikel gegen die Map prüfen
- wenn schon vorhanden, Zufallsartikel suchen und gegen die Map prüfen. Wiederholen, falls Zufallsartikel bereits vorhanden.
- neue Bestellung in die Datenbank einfügen

Aber vorsicht: Im Worst Case (Kunde hat alle Artikel bereits einmal bestellt) hast Du eine Endlosschleife. Das müsstest Du auch irgendwie behandeln.
 

Tellerrand

Bekanntes Mitglied
Ich sehe das auf Datenbank Ebene.
Einfach ein Statement basteln, was als Resultat alle Artikel beherbergt die der Kunde noch nicht gekauft hat.
Und mit dem Resultat kann man dann machen was man will, prüfen ob Artikel x in der Liste ist, oder einen zufälligen aus der Liste bestimmen, oder oder oder...
 
G

Guest

Gast
P3AC3MAK3R hat gesagt.:
Eigentlich mußt Du ja nur per

Code:
select count(*) from kunde-artikel where kunde = x and artikel = y

prüfen, ob die Kombination bereits vorhanden ist, bevor Du einen Eintrag in der Kunde-Artikel-Tabelle vornimmst.

Wenn das der Fall ist, ermittelst Du eben zufällig eine neue Artikelnummer (vielleicht hilft dabei dieser Link weiter) und führst die Prüfung erneut durch.

Und selbst, das ist nicht einmal nötig, sofern in der Tabelle kunde-artikel ein zusammengesetzter primarykey aus kunde und artikel vorhanden ist.

Da reicht es das insert aufzurufen, bzw. das update und dann sieht man ja ob ein eintrag hinzugefügt wurde oder nicht.
wurde keiner hinzugefügt, einfach ein neues produkt aussuchen.

Das ganze kann aber böse enden, wenn keine neuen möglichen Artikel mehr vorhanden sind.
 

thomator

Bekanntes Mitglied
Warum Ihr das Ganze zu Lasten der Datenbank und des Netz-Traffic abwickeln wollt und nicht auf dem Speicher ist mir allerdings nicht so ganz klar... :bahnhof:
 

Tellerrand

Bekanntes Mitglied
thomator hat gesagt.:
Warum Ihr das Ganze zu Lasten der Datenbank und des Netz-Traffic abwickeln wollt und nicht auf dem Speicher ist mir allerdings nicht so ganz klar... :bahnhof:
Ich stell mir eher die Frage wieso man die Aufgabe nun von der Datenbank abkapseln will.
Oder wieso du soviel Speicher verbrauchen willst :p

Warum sollte man eine eigene Lösung basteln die am Ende sehr komplex, fehleranfällig und im Zweifel mehr Ressourcen kostet?
Wozu eine Datenbank wenn man sie nicht belasten darf, eine Datenbank ist doch exakt für solche Fälle geschaffen.
 

thomator

Bekanntes Mitglied
Öhm..... Performance?
Im Ungünstigsten Fall setzt Du bei 1000 vorhandenen Kombinationen für einen Kunden 1000 SQL-Statements ab, nur um zu prüfen, ob so ein Dingen schon da ist. Na herzlichen Glückwunsch!
 

NTB

Bekanntes Mitglied
Nicht bei dem Vorschlag von Tellerand:
Er hatte vorgeschlagen, alle Artikel zu selektieren, die der Kunde noch nicht gekauft hat.

Grundsätzlich sollte man immer versuchen, möglichst viel solcher Anfragen von der Datenbank machen lassen, weil sie nunmal dafür optimiert ist und dazu noch eine sehr einfache Sprache spricht. Natürlich hängt das stark von den Gegebenheiten ab.
 

Tellerrand

Bekanntes Mitglied
thomator hat gesagt.:
Öhm..... Performance?
Im Ungünstigsten Fall setzt Du bei 1000 vorhandenen Kombinationen für einen Kunden 1000 SQL-Statements ab, nur um zu prüfen, ob so ein Dingen schon da ist. Na herzlichen Glückwunsch!

Siehe meinen ersten Post hier.
1 Statement und ich habe eine Liste mit allen noch nicht gekauften Artikeln eines Kunden.
Daraus einen zufälligen Artikel auswählen und fertig.
 
Status
Nicht offen für weitere Antworten.
Ähnliche Java Themen
  Titel Forum Antworten Datum
S GUI-Programmierung Sudoku-Rätsel lösen Java Basics - Anfänger-Themen 1
X Rekursion Rätsel Java Basics - Anfänger-Themen 4
L Symbo Rätsel lösen lassen Java Basics - Anfänger-Themen 3
K Ein kleines Rätsel Java Basics - Anfänger-Themen 2
O Rätsel Java Code Java Basics - Anfänger-Themen 8
T Geocaching Java Rätsel Java Basics - Anfänger-Themen 21
J Rätsel-Spiel - Hilfe! Java Basics - Anfänger-Themen 3
M Ich stehe vor einem Rätsel Java Basics - Anfänger-Themen 3
M Java Rätsel (Geocaching) - Brauch Hilfe dazu! Java Basics - Anfänger-Themen 15
ChackZz Java-Rätsel: Mein erster Versuch Java Basics - Anfänger-Themen 19
J Die Sprache der Informatiker sie bleibt mir ein Rätsel. Java Basics - Anfänger-Themen 8
J Vorschlag für längeres Projekt Java Basics - Anfänger-Themen 27
M Code aus IntelliJ in "Textform" für Word-Paper? Java Basics - Anfänger-Themen 10
G Icon für App Java Basics - Anfänger-Themen 1
Kerstininer Vererbung Hilfe beim lernen von Objektorientierung für eine Klausur Java Basics - Anfänger-Themen 10
Sniper1000 Java 391 für Windows Java Basics - Anfänger-Themen 37
P Wieso kann ich als Index für einen Array einen Char angeben? Java Basics - Anfänger-Themen 3
benny1993 Java Programm erstellen für ein Fußball-Turnier Java Basics - Anfänger-Themen 3
V Durchschnittliche Volatility in Prozent für 4 Stunden berechnen Java Basics - Anfänger-Themen 14
P Welches SDK für das erstellen einer ausführbaren Datei? Java Basics - Anfänger-Themen 4
C negamax-Algorithmus für Tic-Tac-Toe spielt manchmal falsch Java Basics - Anfänger-Themen 10
D Apache HTTPClient für alle Fälle Java Basics - Anfänger-Themen 41
J Layout Manager, welcher ist der Richtige für mein Program? Java Basics - Anfänger-Themen 1
J Fehlermeldung unverständlich für Jakarta Java Basics - Anfänger-Themen 17
M Minimax-Algorithmus für Vier gewinnt Java Basics - Anfänger-Themen 11
M GUI für Vier-Gewinnt. Java Basics - Anfänger-Themen 4
I JPA Query für mehrere Klassen Java Basics - Anfänger-Themen 3
D Quellcode für cmd funktioniert nicht Java Basics - Anfänger-Themen 9
R Operatoren Rechenoperation in Java verwenden für Calculator Java Basics - Anfänger-Themen 2
R Operatoren Rechenoperation verwenden für Taschenrechner. Java Basics - Anfänger-Themen 32
Ostkreuz Counter für Booleanwerte Java Basics - Anfänger-Themen 8
B Regex Ausdrücke für Monate Java Basics - Anfänger-Themen 7
I BlueJ Queue Frage für Klausur Java Basics - Anfänger-Themen 2
K loop pausieren für eine bestimmte Anzahl? Java Basics - Anfänger-Themen 1
Jxhnny.lpz Randomisier für Buttons Java Basics - Anfänger-Themen 13
W Intuitive interface für Komponenten Java Basics - Anfänger-Themen 4
M "Class<T> clazz" im Constructor - auch für int möglich? Java Basics - Anfänger-Themen 7
B Schrankensystem mit Farberkennung für Flashgame funktioniert nicht wie geplant Java Basics - Anfänger-Themen 4
I Code für Bezahlsystem (auch bei Offline Aktivität) Java Basics - Anfänger-Themen 7
U jUnit 5 Test für eine addMethode Java Basics - Anfänger-Themen 18
M monte carlo Algorithmus für 4 gewinnt Java Basics - Anfänger-Themen 12
frager2345 Java Singleton Muster -> Methode für Konstruktor mit Parametern Java Basics - Anfänger-Themen 3
izoards Sortier Algorithmus für Bounding Box Elememte Links nach Rechts und von Oben nach Unten Java Basics - Anfänger-Themen 33
M generate Methode für Streams Java Basics - Anfänger-Themen 6
I Datenmodell für "Tags" Java Basics - Anfänger-Themen 6
Lion.King for-Kontrollstruktur für Pyramide Java Basics - Anfänger-Themen 8
B Mit Countdown Midnestdauer für Teilaufgabenerledigung erzwingen Java Basics - Anfänger-Themen 8
J File length als Prüfwert für Download Java Basics - Anfänger-Themen 5
K Spieleidee gesucht für Informatikprojekt - JAVA (BlueJ)? Java Basics - Anfänger-Themen 15
P Zähler Variable für mehrere Objekte Java Basics - Anfänger-Themen 6
javamanoman Java für Online Banking Java Basics - Anfänger-Themen 12
NadimArazi Wie kann ich eine collision detection für die Paddles in meinem Pong Programm hinzufügen? Java Basics - Anfänger-Themen 4
JordenJost Java ist auch eine Insel für Anfänger Java Basics - Anfänger-Themen 2
P9cman Tipps für Rekursive Aufgaben mit Strings oder allgemein Java Basics - Anfänger-Themen 2
F Suche nach betreuender Person für eine Jahresarbeit der 12. Klasse. Java Basics - Anfänger-Themen 6
I SQL / JPA Query für StartDate und EndDate Java Basics - Anfänger-Themen 1
T getMethode für ein Array Java Basics - Anfänger-Themen 2
Fats Waller Farben mixen für den Hintergrund ? Java Basics - Anfänger-Themen 1
H Suche jemanden für kleine Uni-Abgabe/ mit Vergütung Java Basics - Anfänger-Themen 1
K Für was braucht man die left und right shift operatoren? Was bringen die, also welchen Zweck haben die? Java Basics - Anfänger-Themen 15
N Api nur für Textdatein (.txt) Java Basics - Anfänger-Themen 2
bluetrix Programmieren eines Bots für Zahlen-Brettspiel Java Basics - Anfänger-Themen 9
M Wie kann eine Methode für ein vorhandenes "Array von char" einen Index-Wert zurückliefern? Java Basics - Anfänger-Themen 3
R Ist Java das Richtige für mich? Java Basics - Anfänger-Themen 4
E Mittelquadratmethode für Hexadezimalzahlen Java Basics - Anfänger-Themen 1
P Einfacher regulärer Ausdruck (RegEx) für E-Mail-Adressen Java Basics - Anfänger-Themen 2
Kiki01 Wie würde eine geeignete Schleife aussehen, die die relative Häufigkeit für jeden Charakter in einem Text bestimmt? Java Basics - Anfänger-Themen 3
N Fehler im Code (Aufgabe für Anfänger) Java Basics - Anfänger-Themen 11
O Wie erstelle ich eine Instanz in einer Klasse für die ich die Instanz will? Java Basics - Anfänger-Themen 4
S BubbleSort für ArrayLists Java Basics - Anfänger-Themen 3
T Übungsbuch für Anfänger Java Basics - Anfänger-Themen 3
L Konzept für Quiz Java Basics - Anfänger-Themen 33
D Methoden Plathhalter für Integer in einer Methode Java Basics - Anfänger-Themen 19
B Datentyp für Einzelnes Objekt oder Liste Java Basics - Anfänger-Themen 9
D Welche GUI Library für eine Client Server Chat App Java Basics - Anfänger-Themen 14
T Algorithmus für Index mit min-Wert Java Basics - Anfänger-Themen 2
Aqtox Hallo ich muss für die Schule ein Wuerfell Duell erstellen jedoch habe ich ein fehler Java Basics - Anfänger-Themen 4
L loop für Namen Java Basics - Anfänger-Themen 11
kxrdelis Konstruktor für ein Rechtwinkliges Dreieck Java Basics - Anfänger-Themen 10
S Fehler bei Code mit SubStrings für mich nicht auffindbar. Java Basics - Anfänger-Themen 4
nevel Programm für die Summer der Zahlen 1- 1ß Java Basics - Anfänger-Themen 12
I Entity erstellen, die für API gedacht ist Java Basics - Anfänger-Themen 33
C Archiv für eigene Klassen Java Basics - Anfänger-Themen 9
A Junit Test für MysqlDataSource JDBC Java Basics - Anfänger-Themen 3
Animal-Mother BMI Rechner erstellen für W/M Java Basics - Anfänger-Themen 7
E Kleines Java-Projekt für Anfänger Java Basics - Anfänger-Themen 10
A Java die richtige Programmiersprache für mein Projekt? Java Basics - Anfänger-Themen 1
I DecimalFormat in Zahlenformat für Währung, habe 7,99, bekomme aber 7 Java Basics - Anfänger-Themen 4
L Methode für Zweidimensionale Arrays Java Basics - Anfänger-Themen 4
Kanaska Datentyp für Zahlenbereiche Java Basics - Anfänger-Themen 7
T Startbildschirm für ein Spiel erstellen Java Basics - Anfänger-Themen 0
U BestPractise für Deployment unter Windows gesucht Java Basics - Anfänger-Themen 12
lilrack UML Diagramm für Parkplatzverwaltung Java Basics - Anfänger-Themen 8
W Mehrfach das gleiche Attribut für ein Objekt erzeugen (mit verschiedenen Werten) Java Basics - Anfänger-Themen 2
B Generische Typen für dynamisches Formular Java Basics - Anfänger-Themen 3
C Was ist nötig für ein Java-Programm auf Server für Website Java Basics - Anfänger-Themen 18
T Vererbung Verschiedene Attribute für vererbte Klassen Java Basics - Anfänger-Themen 4
T Start-Activity für Java Maven Web-Anwendung festlegen Java Basics - Anfänger-Themen 2
T Alternative für switch case Java Basics - Anfänger-Themen 1
P Ressourcen für JSON & API Informationen? Java Basics - Anfänger-Themen 1

Ähnliche Java Themen

Neue Themen


Oben