String Kombination erstellen anhand fortlaufender Zahl (Vertragsnummer)

internet

Top Contributor
Hallo,

ich würde gerne für eine Vertragsverwaltung meine Vertragsnummer in der Form gestalten, sodass man nicht gleich nachvollziehen kann, wieviel Verträge ich habe.
Eine Nummer darf es nur 1x geben.

Beispiel:
PAS6-AS8D

Das ganze soll durch eine fortlaufende Nummer erstellt werden:
Also:
1 = PAS6-AS8D
2 = POAO-AS3D

Wie könnte man sowas lösen?

Klar, ich könnte natürlich einen Zufallsstring generieren und dann jedes Mal gegen die Datenbank prüfen, ob es diese Vertragsnummer schon gibt. Aber das würde dann u.U. mehrere SQL Abfragen sein (falls die Vertragsnummer bereits besteht)...

Danke für jede Hilfe
 

mrBrown

Super-Moderator
Mitarbeiter
Wir haben mal für eine eindeutige ID einfach die Unix-Timestamp hergenommen und die zur einfacheren Lesbarkeit als Hexwert verwendet.
Da muss man allerdings aufpassen, dass nur eine pro Sekunde erzeigt werden darf.

Klar, ich könnte natürlich einen Zufallsstring generieren und dann jedes Mal gegen die Datenbank prüfen, ob es diese Vertragsnummer schon gibt. Aber das würde dann u.U. mehrere SQL Abfragen sein (falls die Vertragsnummer bereits besteht)...
Das musst du so oder so machen, wenn Eindeutigkeit gefordert ist.

Die Wahrscheinlichkeit von Kollisionen kannst du dann nur über die Länge reduzieren. UUIDs zB sind lang genug, dass doppelte IDs nahezu ausgeschlossen sind, aber durch die Länge nicht wirklich praktikabel.
 

Neumi5694

Top Contributor
Du kannst anstatt der Systemzeit auch einem Random-Long wert verwenden, um irgendwas daraus zu erstellen.
Wichtig ist, dass du eine zentrale Stelle hast, welche die IDs vergibt und bei Erstelleung auch gleich mit prüft, ob die ID schon vergeben ist und dann gegebenenfalls eine neue generiert.
 
G

Gelöschtes Mitglied 65838

Gast
Du kannst anstatt der Systemzeit auch einem Random-Long wert verwenden, um irgendwas daraus zu erstellen.
Wichtig ist, dass du eine zentrale Stelle hast, welche die IDs vergibt und bei Erstelleung auch gleich mit prüft, ob die ID schon vergeben ist und dann gegebenenfalls eine neue generiert.
die zentrale stelle wäre eine datenbank ... die wird das schon gebacken kriegen einen eindeutigen key erzeugen zu können aber das ist ja nicht gewünscht

also muss man da schon weit ausholen

random key erzeugen -> db fragen obs schon gibt -> wenns schon gibt dann gleich nochmal einen erzeugen
 

mrBrown

Super-Moderator
Mitarbeiter
die zentrale stelle wäre eine datenbank ... die wird das schon gebacken kriegen einen eindeutigen key erzeugen zu können aber das ist ja nicht gewünscht
Die meisten DBs können entweder fortlaufende Nummern generieren, das widerspricht der einzigen Anforderung:
ich würde gerne für eine Vertragsverwaltung meine Vertragsnummer in der Form gestalten, sodass man nicht gleich nachvollziehen kann, wieviel Verträge ich habe.
oder genieren UUIDs, die alles andere als Menschen-Benutzbar sind ;)
 

berndoa

Top Contributor
Ich muss da gerade an die Sache mit der Diagonalisierung denken, die mir mal in einem MAthebeweis enutzt wurde:
Du hast also eine Liste an schon vorhandenen Nummern, wie bspw.
1 = PAS6-AS8D
2 = POAO-AS3D

Dann generierst du eine (in dem Fall 8 stellige) neue Nummer, in dem
du guckst dass die 1. ziffer nicht mit der 1. ziffer der ersten Zahl überinstimmt
(also mit was anderem als P beginnt)
Dann 2. ziffer was anderes als die 2. ziffer der 2. zahl
(also als 2. ziffer kein O benutzen)
etc.

klingt umständlich, mahct aber sinn und stellt sicher dass sich die erzeugte Zahl iM Vergleich zu jeder der bisherigen Nummern in mindestens einer Ziffer unterscheidet.
Hier mit nur 2 Zahlen bisher war das "overkill", da würde es schon reichen wenn du die Zahl mit Q oder so beginnst.
Das funktioniert erst besser wenn du mehr als 8 Zahlen da hast (also zahlenanzahl>Zahlenlänge).

Oder so.

Zumindest lässt sich diese Methode hier sicherlich abgewandelt irgendwie anwenden.

Das kam in mathe vor als es zu beweisne galt dass die Menge an reellen zahlen (bzw. bereits alle Zahlen der Form 0.irgendwas) überabzählbar ist :)
 

Oneixee5

Top Contributor
Du könntest so etwas versuchen:
Java:
//    final List<Character> list = Arrays.asList('A', 'B', 'C', 'D', 'E', 'F', 'G', 'H', 'I', 'J', 'K', 'L', 'M', 'N',
//            'O', 'P', 'U', 'V', 'W', 'X', 'Y', 'Z', '0', '1', '2', '3', '4', '5', '6', '7', '8', '9');
//    Collections.shuffle(list);


    private static final List<Character> CHARS1 = Arrays.asList('Y', '7', 'B', '4', 'C', 'D', 'H', 'P', 'Z', 'O', 'E',
            '0', 'L', '1', '5', '9', '3', 'V', 'N', 'J', 'F', 'U', 'K', '2', 'X', 'A', '6', 'I', 'W', '8', 'M', 'G');

    private static final List<Character> CHARS2 = Arrays.asList('P', '1', 'V', 'D', 'B', 'O', 'H', 'Y', 'W', 'F', '0',
            'E', 'M', '5', 'U', 'I', '8', '9', 'K', 'N', 'J', 'X', 'Z', 'G', '6', '4', 'L', '3', 'A', '7', '2', 'C');

    public static String convert(final List<Character> chars, int decimal) {
        int index;
        String result = "";
        final int len = chars.size();
        while (decimal > 0) {
            index = decimal % len;
            result = chars.get(index) + result;
            decimal = decimal / len;
        }
        return result;
    }

    public static void main(final String args[]) {

        final Set<String> set = new HashSet<>();
        String contractId;
        for (int i = 1; i < 1000000000; i++) {
            contractId = convert(CHARS1, 1000000000 + i) + "-" + convert(CHARS2, 1000000000 + i);
            set.add(contractId);

            if (i % 1000 == 0) {
                final long heapFreeSize = Runtime.getRuntime().freeMemory();
                System.out.format("round: %s \t   free heap size: %s \t example contract id: %s%n",
                        i, humanReadableByteCount(heapFreeSize), contractId);

                if (i > 1000000 && heapFreeSize < 120000000) {
                    // low memory, here it probably makes no sense to continue
                    throw new OutOfMemoryError();
                }
            }

            //System.out.println(" of " + i + " is: \t" + convert(CHARS1, 1000000000 + i) + "-" + convert(CHARS2, 1000000000 + i));
        }

        System.out.format("resulting set contains %s unique items", set.size());
    }

    public static String humanReadableByteCount(final long bytes) {
        final long absB = bytes == Long.MIN_VALUE ? Long.MAX_VALUE : Math.abs(bytes);
        if (absB < 1024) {
            return bytes + " B";
        }
        long value = absB;
        final CharacterIterator ci = new StringCharacterIterator("KMGTPE");
        for (int i = 40; i >= 0 && absB > 0xfffccccccccccccL >> i; i -= 10) {
            value >>= 10;
            ci.next();
        }
        value *= Long.signum(bytes);
        return String.format("%.1f %ciB", value / 1024.0, ci.current());
    }
Man erschafft quasi sein eigenes Zahlensystem, welches man sogar wieder ins Dezimalsystem umrechnen könnte.
Wenn du nicht in der DB nachschauen willst, ob Vertragsnummern kollidieren, dann kann man sich einen Vorrat an eindeutigen Vertragsnummern speichern. Das wird hier in einem Set gemacht. Diesen Vorrat müsste man natürlich irgendwo speichern und benutzte Vertragsnummern entfernen. Wie so eine Art Sequenz in einer DB.
Code:
round: 37458000        free heap size: 182,3 MiB      example contract id: M8LKN3-27MZK8
round: 37459000        free heap size: 180,3 MiB      example contract id: M8L2VX-27MG96
round: 37460000        free heap size: 179,3 MiB      example contract id: M8LXVY-27M69P
round: 37461000        free heap size: 177,3 MiB      example contract id: M8LA3Z-27M48W
round: 37462000        free heap size: 175,3 MiB      example contract id: M8L693-27MLI8
round: 37463000        free heap size: 174,3 MiB      example contract id: M8LI5X-27M3U6
round: 37464000        free heap size: 172,3 MiB      example contract id: M8LW5Y-27MAUP
round: 37465000        free heap size: 171,3 MiB      example contract id: M8L81Z-27M75W
Für das Beispiel muss man darauf achten, dass der JVM genug Speicher zur Verfügung steht - und das dauert ein Weilchen!
 

Oneixee5

Top Contributor
Man könnte das auch so machen:
Java:
        for (int i = 1; i < 1000000000; i++) {
            for (int j = 1; i < 1000000000; j++) {
                contractId = convert(CHARS1, 1000000000 + i) + "-" + convert(CHARS2, 1000000000 + j);
                set.add(contractId);
...
Dann wäre der Bereich der erzeugten Vertragsnummern noch viel größer.
 

mihe7

Top Contributor
Wobei mir hier ein String für das Alphabet besser gefallen würde. Außerdem muss man die Darstellung der Zahl nicht unbedingt mit der höchstwertigen Stelle beginnen lassen :)
Java:
    public static String convert(final String chars, int decimal) {
        int index;
        StringBuilder result = new StringBuilder();
        final int len = chars.length();
        while (decimal > 0) {
            index = decimal % len;
            result.append(chars.charAt(index));
            decimal = decimal / len;
        }
        return result.toString();
    }

EDIT: noch ein Beispiel:
Code:
jshell> System.out.println(convert("AB3C4P5Q7S6", 2021) + "-" + convert("42A31F75G9Z60X", 10006))
7QPB-Z493
jshell> System.out.println(convert("AB3C4P5Q7S6", 2021) + "-" + convert("42A31F75G9Z60X", 10012))
7QPB-A293
 
Zuletzt bearbeitet:

Oneixee5

Top Contributor
Wobei mir hier ein String für das Alphabet besser gefallen würde. Außerdem muss man die Darstellung der Zahl nicht unbedingt mit der höchstwertigen Stelle beginnen lassen
Ja, das stimmt, es handelt sich nicht um eine fertige Implementierung. Der Code ist als Beispiel gedacht und die Chars sollten sich leicht an Zufallskombinationen anpassen lassen. Die Vertragsnummern sollten immer die einheitliche maximale Länge haben. Es kann gern alles geändert und verbessert werden.
 
Ähnliche Java Themen
  Titel Forum Antworten Datum
krgewb String mit Datumsangabe in Long umwandeln Java Basics - Anfänger-Themen 2
D String Groß/Kleinschreibung Ignorieren Java Basics - Anfänger-Themen 4
D Map<String, Integer> sortieren und der reinfolge nach die Glieder abfragen Java Basics - Anfänger-Themen 3
J Ähnlichen String in Liste finden Java Basics - Anfänger-Themen 6
Kartoffel_1 String transformation Java Basics - Anfänger-Themen 7
H String-Operation replace() - Zeichenkette verdoppeln Java Basics - Anfänger-Themen 2
K String analysieren Java Basics - Anfänger-Themen 27
Beowend String zu Date parsen Java Basics - Anfänger-Themen 1
Beowend String auf Satzzeichen überprüfen? Java Basics - Anfänger-Themen 6
H Liste nach String-Länge sortieren Java Basics - Anfänger-Themen 1
String in ArrayList umwandeln Java Basics - Anfänger-Themen 1
I Sass Compiler und String erhalten? Java Basics - Anfänger-Themen 7
Avalon String in Double bzw. Währung konvertieren Java Basics - Anfänger-Themen 6
T Methode akzeptiert String nicht Java Basics - Anfänger-Themen 18
F Arraylist<String>Ein Wort pro Zeile Java Basics - Anfänger-Themen 6
J Schlüsselworte Prüfen, ob ein bestimmtes, ganzes Wort in einem String enthalten ist. Java Basics - Anfänger-Themen 6
N String überprüfen Java Basics - Anfänger-Themen 3
E String zerlegen aus args Java Basics - Anfänger-Themen 1
M Long-Typ in String-Änderung führt zu keinem Ergebnis bei großer Zahl Java Basics - Anfänger-Themen 11
Ostkreuz String Exception Java Basics - Anfänger-Themen 8
W Items löschen aus String Array vom Custom Base Adapter Java Basics - Anfänger-Themen 2
MoxMorris Wie macht man String[] = String[] aus einer anderer Methode? Java Basics - Anfänger-Themen 18
J String Filter Java Basics - Anfänger-Themen 5
S String Array Buchstaben um einen gewissen Wert verschieben Java Basics - Anfänger-Themen 4
R Größter zusammenhängender Block gleicher Zeichen im String Java Basics - Anfänger-Themen 1
XWing Randomizer mit einem String Java Basics - Anfänger-Themen 2
D 2D Char Array into String Java Basics - Anfänger-Themen 2
H Cast von Float nach String klappt nicht Java Basics - Anfänger-Themen 12
I Zerlegen von String Java Basics - Anfänger-Themen 3
B Beliebiger String gegeben Suche Datum in String Java Basics - Anfänger-Themen 6
I String Java Basics - Anfänger-Themen 4
I API - zurückgegebener JSON String lesen und in Entity konvertieren Java Basics - Anfänger-Themen 2
H Zu langen String aufteilen - bequeme Methode? Java Basics - Anfänger-Themen 14
W String einer Textdatei in einzelne Stringobjekte pro Zeile aufteilen Java Basics - Anfänger-Themen 14
belana wie am besten 2D Array von String to Integer Java Basics - Anfänger-Themen 18
J Java To String Methode, Array mit For-Schleife Java Basics - Anfänger-Themen 2
M Kommandozeilenparamter als EINEN String werten Java Basics - Anfänger-Themen 5
M RandomAccessFile int und String gleichzeitig in einer Datei Java Basics - Anfänger-Themen 49
M Prüfen on eine Zahl im String enthalten ist Java Basics - Anfänger-Themen 3
Distanz zwischen zwei Zeichenfolgen in einem String bestimmen Java Basics - Anfänger-Themen 5
Substring in einem String finden Java Basics - Anfänger-Themen 13
BeginnerJava String mit vorgegebener Länge und Buchstaben erzeugen/ mit Leerstellen Java Basics - Anfänger-Themen 8
I Eindeutiger String mit maximaler Anzahl an Zeichen Java Basics - Anfänger-Themen 11
H Interface Wieso "List<String> list = new ArrayList<>[…]" Java Basics - Anfänger-Themen 4
JavaBeginner22 Integer in String umwandeln Java Basics - Anfänger-Themen 7
HolyFUT JSON String in Java Object schreiben - Anführungszeichen rauskriegen? Java Basics - Anfänger-Themen 17
Fodoboo131 RegEx- Umwandlung von String in ausführbares Objekt/ Befehl Java Basics - Anfänger-Themen 9
HolyFUT Input/Output Leerzeichen aus String entfernen - klappt nicht! Java Basics - Anfänger-Themen 13
viktor1 Methoden Methode schreiben static void readText (String filename) {...} zu WordHistogramSample.java Java Basics - Anfänger-Themen 13
ravenz Schleife mit for über String Array „zahlen“und prüfen ob Wert „a“ oder „b“ oder „c“ entspricht (mittels || ) Java Basics - Anfänger-Themen 4
G Position einer unbekannten 3-stelligen-Zahl in einem String finden Java Basics - Anfänger-Themen 15
T String Array Fehler beim Index Java Basics - Anfänger-Themen 3
H Erste Schritte Nach einer Zahl n soll n Mal der String untereinander ausgegeben werden Java Basics - Anfänger-Themen 3
X Datentypen String.equals funktioniert nicht Java Basics - Anfänger-Themen 5
Alen123 String wiederholen mit Schleifen Java Basics - Anfänger-Themen 1
A String split funktioniert nicht, wenn mehr als 1 Ziffer vor dem Zeichen steht nach dem er trennen soll? Java Basics - Anfänger-Themen 4
T String splitten Java Basics - Anfänger-Themen 3
sserio Schwimmen als Spiel. Problem mit to String/ generate a card Java Basics - Anfänger-Themen 4
J Datentypen String in File konvertieren funktioniert nicht Java Basics - Anfänger-Themen 4
T Platzhalter in String? Java Basics - Anfänger-Themen 14
M String mit Variable vergleichen Java Basics - Anfänger-Themen 9
Fats Waller Compiler-Fehler Kann ich einen String und die Summe zweier Char Werte mittels der println Anweisung ausgeben Java Basics - Anfänger-Themen 4
M Wie kann eine Methode (string) eine andere Methode (void) mit zufälligen int-Werten aufrufen? Java Basics - Anfänger-Themen 4
P9cman Vokale in einem String überprüfen mittels Rekursion Java Basics - Anfänger-Themen 8
schredder Strings und reguläre Ausdrücke - Methode mit return string.matches Java Basics - Anfänger-Themen 5
R Ein Multidimensionales String Array initialisieren und Deklarieren Java Basics - Anfänger-Themen 2
H String Repräsentation eines Rechtecks mit Instanz-Methode Java Basics - Anfänger-Themen 8
Dorfschmied Kartesisches Produkt von zwei Liste mit Hashmaps<String,String> erstellen Java Basics - Anfänger-Themen 4
S String mit Int input vergleichen Java Basics - Anfänger-Themen 5
C String/Char-API Java Basics - Anfänger-Themen 13
U Char zu einem String machen Java Basics - Anfänger-Themen 1
B Anzahl Nullen uns Einsen in String ermitteln Java Basics - Anfänger-Themen 3
T Leerzeichen im String entfernen Java Basics - Anfänger-Themen 6
Jose05 Nullpointerexception bei Umwandlung von String zu int Java Basics - Anfänger-Themen 2
O Ich habe einen String und soll mit matches schauen, ob ein Buchstabe zu einer geraden ANzahl im String vorkommt, wie soll das gehen? Java Basics - Anfänger-Themen 7
M String beim einlesen formatieren Java Basics - Anfänger-Themen 12
N null in String replacen Java Basics - Anfänger-Themen 16
R Compiler-Fehler JTable mit XML befüllen | The constructor JTable(Object[], String[]) is undefined Java Basics - Anfänger-Themen 10
M Eclipse kennt keine String Klasse mehr Java Basics - Anfänger-Themen 1
M Frage zur Methode split der Klasse String Java Basics - Anfänger-Themen 32
D String mit int multiplizieren? Java Basics - Anfänger-Themen 16
H Überprüfen ob String Array leer ist Java Basics - Anfänger-Themen 4
A Korrigierte <String> Liste zurückgeben Java Basics - Anfänger-Themen 22
C In String, Buchstaben ersetzen durch andere Buchstaben Java Basics - Anfänger-Themen 26
Poppigescorn String mit mehreren Wörtern füllen? Java Basics - Anfänger-Themen 4
I String Expression mit Java validieren (true / false) Java Basics - Anfänger-Themen 34
B String - Wörter finden, welches Punkt und entsprechender Pre / Suffix hat? Java Basics - Anfänger-Themen 30
T Maximale Anzahl von Konsonanten im String Java Basics - Anfänger-Themen 6
H String verschlüsseln - eigener Algorithmus Java Basics - Anfänger-Themen 104
N Aus einem String die Anzahl der Vokale auslesen Java Basics - Anfänger-Themen 40
J Eintrag Combobox über einen String auswählen Java Basics - Anfänger-Themen 3
K mit String.splitt(",") ganzen Satz erhalten? Java Basics - Anfänger-Themen 3
K Wie String prüfen ob drei mal das gleiche Zeichen vorkommt? Java Basics - Anfänger-Themen 7
I Validation, ob String ein Wert aus einem Enum enthält Java Basics - Anfänger-Themen 3
D String und char in String speichern Java Basics - Anfänger-Themen 5
A ObservableList<String> Java Basics - Anfänger-Themen 6
I String nach Wort suchen Java Basics - Anfänger-Themen 6
I String ersetzen, der Inhalt enthält Java Basics - Anfänger-Themen 4
L ArrayList<String> --> double[] array Java Basics - Anfänger-Themen 18
J Variablenzugriff über string Java Basics - Anfänger-Themen 18

Ähnliche Java Themen

Neue Themen


Oben