Auto increment ab dem Wert 00001 in MySQL
In MySQL Tabelle erstellen und mit dem Wert (z.B) mit "00001" beginnen
->Wie geht das?
Sinn und Zweck:
1) Es würde ästhetisch besser besser aussehen (später für PHP)
2) Ich will nicht jedes mal alter table machen, wenn ich schon 200 Einträge habe
etc. etc.
create table test NOT NULL auto_increment=000001 ------------> geht nicht, ebenso wie MyIsam Vorschläge.
Hääälp :- ) nein spass
Wäre mich auf einen Lösungsvorschlag freuen. Ich arbeite übrigens mit XAMPP
Viele Grüsse und Danke im Voraus!!!
->Wie geht das?
Sinn und Zweck:
1) Es würde ästhetisch besser besser aussehen (später für PHP)
2) Ich will nicht jedes mal alter table machen, wenn ich schon 200 Einträge habe
etc. etc.
create table test NOT NULL auto_increment=000001 ------------> geht nicht, ebenso wie MyIsam Vorschläge.
Hääälp :- ) nein spass
Wäre mich auf einen Lösungsvorschlag freuen. Ich arbeite übrigens mit XAMPP
Viele Grüsse und Danke im Voraus!!!
Bitte markiere auch die Kommentare, die zur Lösung des Beitrags beigetragen haben
Content-ID: 156150
Url: https://administrator.de/forum/auto-increment-ab-dem-wert-00001-in-mysql-156150.html
Ausgedruckt am: 11.01.2025 um 00:01 Uhr
8 Kommentare
Neuester Kommentar
Moin yxcvbnm1234,
[OT]
Seit ich meinen Rechner auf automatische Spracherkennung umgeswitcht habe finde ich deinen Nick irgendwie suboptimal.
[OT]
Du kannst zum Beispiel den Startwert definieren beim CREATE TABLE oder wenn es die Tabelle nun mal schon gibt mit ALTER TABLE.
... mit den zu berücksichtigenden (eigentlich logischen) Rahmenbedingungen
Grüße
Biber
P.S. die erste Frage nach Auto_increment 0001 habe ich als obsolet betrachtet und ignoriert - das geht wirklich nicht. Und wäre auch pottenhässlich.
[OT]
Seit ich meinen Rechner auf automatische Spracherkennung umgeswitcht habe finde ich deinen Nick irgendwie suboptimal.
[OT]
Du kannst zum Beispiel den Startwert definieren beim CREATE TABLE oder wenn es die Tabelle nun mal schon gibt mit ALTER TABLE.
ALTER TABLE test AUTO_INCREMENT = startwert; -- z.B. 1000
- keine Angabe eines Feldnamens. Es kann ja nur ein AUTO_INCREMENT-Feld je Tabelle geben. "AUTO_INCREMENT = whatever" ist eine TABLE OPTION (keine COLUMN-Option)
- der Startwert muss größer sein als alles, was bereits an Werten da ist oder jemals da war!
- der Startwert gilt für alle neuen Sätze. Wenn du schon Werte von 1 bis 200 in der Tabelle hast..wird alles neu durchgezählt.
- genauer gesagt - die bisherige Tabelle A wird kopiert, umbenannt, neue Tabelle B mit Namen & Struktur von A angelegt und der gesamte Inhalt von A nach B geschaufelt.
- Bedeutet: wenn schon 100000 Datensätze in Tabelle A sind brauchst du Plattenplatz und Tablespace für rund 2einhalb mal 100000 Datensätze
- wenn dir während dieser Operation der Server abraucht mit einem out-of-space-Fehler--> Lauf!
- und der Vollständigkeit halber - Experimente mit negativen Startwerten nie nie nie an einer "produktiven Tabelle" (oder bei jemand, der schneller rennen kann als du).
Grüße
Biber
P.S. die erste Frage nach Auto_increment 0001 habe ich als obsolet betrachtet und ignoriert - das geht wirklich nicht. Und wäre auch pottenhässlich.
Hi !
Also da muss ich leicht widersprechen, denn technisch ist das schon machbar, zumindest indirekt über den Vorschlag von maretz mittels der Formatierung der Felddarstellung. Der Inhalt des Feldes in der Datenbank selbst bleibt davon natürlich unberührt. Unter Delphi z.B. geht das über das Property DisplayFormat des tField Objektes.
Ich fürchte aber leider auch den Grund für seine komische Formatierung, vermutlich geht es um Auftrags oder Rechnungsnummern. Wo wir dann wieder beim leidigen Thema über den "sinnvollen" Einsatz von Autoinc-Felder angekommen wären.
mrtux
Zitat von @Biber:
P.S. die erste Frage nach Auto_increment 0001 habe ich als obsolet betrachtet und ignoriert - das geht wirklich nicht. Und
wäre auch pottenhässlich.
P.S. die erste Frage nach Auto_increment 0001 habe ich als obsolet betrachtet und ignoriert - das geht wirklich nicht. Und
wäre auch pottenhässlich.
Also da muss ich leicht widersprechen, denn technisch ist das schon machbar, zumindest indirekt über den Vorschlag von maretz mittels der Formatierung der Felddarstellung. Der Inhalt des Feldes in der Datenbank selbst bleibt davon natürlich unberührt. Unter Delphi z.B. geht das über das Property DisplayFormat des tField Objektes.
Ich fürchte aber leider auch den Grund für seine komische Formatierung, vermutlich geht es um Auftrags oder Rechnungsnummern. Wo wir dann wieder beim leidigen Thema über den "sinnvollen" Einsatz von Autoinc-Felder angekommen wären.
mrtux
Moin mrtux,
Da stimme ich zu.
Und bevor ich eine vierfach geschraubte REPLACE()/SUBSTRING()/CONCAT()-Arie mache, lasse ich doch lieber die Rechnungsnummern mit 1000 beginnen.
Oder vielmehr mit 20100000 in diesem Jahr (dann ist die erste Rechnungsnummer 20100001 ->die erste im Jahr 2010.
4stellig, wenn ich mit max. 9999 neuen "Nummern" pro Jahr rechne.
Nächstes Jahr setze ich AUTO_INCREMENT dann auf 20110000 ....voila.
Ist doch hybscher als ein LPAD( autoincfeld, 4, '0') oder ähnliches Gewurschtel.
Okay, in produktiven Datenbanken wird sich wohl keiner so rauslügen.
Und AUTO_INCREMENT gerade bei Rechnungs/Belegnummern, die in der Realität einerseits "lückenlos" sein sollen,
andererseits aber bei Bedarf nochmal "neu geschrieben" werden sollen.... das klappt eher selten.
Grüße
Biber
Da stimme ich zu.
zumindest indirekt über den Vorschlag von maretz mittels der Formatierung der Felddarstellung.
Ja nee... aber nicht mit der mySQL-Funktion NUMBER_FORMAT(). Damit bekomme ich Dezimaltrenner und Tausenderpunkte gebacken und zur Not ein Euro-Zeichen. Aber keine führenden Nullen. Und auch mit FORMAT() geht es nicht ohne Verrenkungen.Und bevor ich eine vierfach geschraubte REPLACE()/SUBSTRING()/CONCAT()-Arie mache, lasse ich doch lieber die Rechnungsnummern mit 1000 beginnen.
Oder vielmehr mit 20100000 in diesem Jahr (dann ist die erste Rechnungsnummer 20100001 ->die erste im Jahr 2010.
4stellig, wenn ich mit max. 9999 neuen "Nummern" pro Jahr rechne.
Nächstes Jahr setze ich AUTO_INCREMENT dann auf 20110000 ....voila.
Ist doch hybscher als ein LPAD( autoincfeld, 4, '0') oder ähnliches Gewurschtel.
Der Inhalt des Feldes in der Datenbank selbst bleibt davon natürlich unberührt.
Unter Delphi z.B. geht das über das Property DisplayFormat des tField Objektes.
Okay, wenn er Delphi hat... Unter Delphi z.B. geht das über das Property DisplayFormat des tField Objektes.
Ich fürchte aber leider auch den Grund für seine komische Formatierung, vermutlich geht es um Auftrags oder Rechnungsnummern.
Wo wir dann wieder beim leidigen Thema über den "sinnvollen" Einsatz von Autoinc-Felder angekommen wären.
Was solls... AUTO_INCREMENT-IDs benutzen viele im ersten Ausbildungsjahr... da bin ich tolerant.Wo wir dann wieder beim leidigen Thema über den "sinnvollen" Einsatz von Autoinc-Felder angekommen wären.
Okay, in produktiven Datenbanken wird sich wohl keiner so rauslügen.
Und AUTO_INCREMENT gerade bei Rechnungs/Belegnummern, die in der Realität einerseits "lückenlos" sein sollen,
andererseits aber bei Bedarf nochmal "neu geschrieben" werden sollen.... das klappt eher selten.
Grüße
Biber
Moin,
das Number_Format in MySQL war eher nen Zufall das der Befehl da so heisst... Ich kenne das bei anderen Sprachen (PHP, Java) - und da wäre das meine erste wahl für sowas...
wobei ich beim rest zustimme... Auto-Increment nutze ich nur bei meinen internen ID-Werten. Und da ist es mir zimlich egal wie die formatiert sind - da die eh niemand ausser mir und der datenbank sieht... Und glaubt mir - die schmutzigen Geheimnisse die wir da so ausmachen werde ich nie öffentlich sagen ;)
das Number_Format in MySQL war eher nen Zufall das der Befehl da so heisst... Ich kenne das bei anderen Sprachen (PHP, Java) - und da wäre das meine erste wahl für sowas...
wobei ich beim rest zustimme... Auto-Increment nutze ich nur bei meinen internen ID-Werten. Und da ist es mir zimlich egal wie die formatiert sind - da die eh niemand ausser mir und der datenbank sieht... Und glaubt mir - die schmutzigen Geheimnisse die wir da so ausmachen werde ich nie öffentlich sagen ;)