Top-Themen

Aktuelle Themen (A bis Z)

Administrator.de FeedbackApache ServerAppleAssemblerAudioAusbildungAuslandBackupBasicBatch & ShellBenchmarksBibliotheken & ToolkitsBlogsCloud-DiensteClusterCMSCPU, RAM, MainboardsCSSC und C++DatenbankenDatenschutzDebianDigitiales FernsehenDNSDrucker und ScannerDSL, VDSLE-BooksE-BusinessE-MailEntwicklungErkennung und -AbwehrExchange ServerFestplatten, SSD, RaidFirewallFlatratesGoogle AndroidGrafikGrafikkarten & MonitoreGroupwareHardwareHosting & HousingHTMLHumor (lol)Hyper-VIconsIDE & EditorenInformationsdiensteInstallationInstant MessagingInternetInternet DomäneniOSISDN & AnaloganschlüsseiTunesJavaJavaScriptKiXtartKVMLAN, WAN, WirelessLinuxLinux DesktopLinux NetzwerkLinux ToolsLinux UserverwaltungLizenzierungMac OS XMicrosoftMicrosoft OfficeMikroTik RouterOSMonitoringMultimediaMultimedia & ZubehörNetzwerkeNetzwerkgrundlagenNetzwerkmanagementNetzwerkprotokolleNotebook & ZubehörNovell NetwareOff TopicOpenOffice, LibreOfficeOutlook & MailPapierkorbPascal und DelphiPeripheriegerätePerlPHPPythonRechtliche FragenRedHat, CentOS, FedoraRouter & RoutingSambaSAN, NAS, DASSchriftartenSchulung & TrainingSEOServerServer-HardwareSicherheitSicherheits-ToolsSicherheitsgrundlagenSolarisSonstige SystemeSoziale NetzwerkeSpeicherkartenStudentenjobs & PraktikumSuche ProjektpartnerSuseSwitche und HubsTipps & TricksTK-Netze & GeräteUbuntuUMTS, EDGE & GPRSUtilitiesVB for ApplicationsVerschlüsselung & ZertifikateVideo & StreamingViren und TrojanerVirtualisierungVisual StudioVmwareVoice over IPWebbrowserWebentwicklungWeiterbildungWindows 7Windows 8Windows 10Windows InstallationWindows MobileWindows NetzwerkWindows ServerWindows SystemdateienWindows ToolsWindows UpdateWindows UserverwaltungWindows VistaWindows XPXenserverXMLZusammenarbeit
GELÖST

Auto increment ab dem Wert 00001 in MySQL

Frage Entwicklung Datenbanken

Mitglied: yxcvbnm1234

yxcvbnm1234 (Level 1) - Jetzt verbinden

01.12.2010 um 14:21 Uhr, 7177 Aufrufe, 8 Kommentare

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!!!
Mitglied: maretz
01.12.2010 um 14:43 Uhr
dein auto-increment ist nur für integer-werte möglich. Da gibt es aber keine führende 0....

du kannst nur die Ausgabe ändern - z.b. mit NumberFormat o.ä.
Bitte warten ..
Mitglied: yxcvbnm1234
01.12.2010 um 15:10 Uhr
Danke dass du so schnell geantwortet hast.

Sorry. Was bedeutet mit "NumberFormat"?

Ich kann auf "0001" verzichten. Wie wäre es mit "1000" für den Anfang?

Also create table bla ...

??

Grüsse
Bitte warten ..
Mitglied: maretz
01.12.2010 um 15:38 Uhr
entweder mit nem normalen db-tool (db manager, webmin,...) oder du müsstest das genaue statement mal bei mysql/documentation gucken...
Bitte warten ..
Mitglied: Biber
01.12.2010 um 18:00 Uhr
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.

01.
ALTER TABLE test  AUTO_INCREMENT = startwert;  -- z.B. 1000
... mit den zu berücksichtigenden (eigentlich logischen) Rahmenbedingungen
  • 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.
Bitte warten ..
Mitglied: yxcvbnm1234
01.12.2010 um 21:48 Uhr
Hallo Biber

Vielen Dank für deinen Antwort.Ja, in puncto Nickname-Festlegung bin ich tatsächlich etwas obsolet :- )

Die Antwort reicht mir völlig. Ich stempfle die Frage jetzt wohl als gelöst, nochmals vielen Dank!


Viele Grüsse
Bitte warten ..
Mitglied: mrtux
02.12.2010 um 02:53 Uhr
Hi !

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.

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
Bitte warten ..
Mitglied: Biber
02.12.2010 um 07:12 Uhr
Moin mrtux,


Zitat von mrtux:
Also da muss ich leicht widersprechen, denn technisch ist das schon machbar, ...
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...

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.
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
Bitte warten ..
Mitglied: maretz
02.12.2010 um 08:02 Uhr
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 ;)
Bitte warten ..
Ähnliche Inhalte
Datenbanken
MYSQL Abfrage Werte summieren
gelöst Frage von Ghost108Datenbanken3 Kommentare

Hallo zusammen, ich habe folgende Tabelle: Möchte gerne eine SQL Abfrage haben: - welche mir eine Spalte ausgibt, wo ...

PHP
MySQL-Abfrage mit php: Wert + true bzw. false
Frage von tomolpiPHP2 Kommentare

Moin Leute, Frage an die PHP-Experten: mit bekomme ich über data.php?id=123 den passenden Wert, in diesem Fall hans. Da ...

Microsoft Office
Auto Vervollständigen
gelöst Frage von AndreasFredersdorfMicrosoft Office5 Kommentare

Hallo, ich habe zwei Fragen: 1) Microsoft Excel 2007: AutoVervollständigen ist gesetzt, Hochkomma in der ersten Zelle gesetzt. Funktioniert ...

VB for Applications
Auto-Update für COM-Addin
gelöst Frage von MarcoBornVB for Applications2 Kommentare

Hallo Forum, Ich habe ein COM-Addin geschrieben. Nun möchte ich einen Auto-Update-Mechanismus implementieren, der immer beim Aufruf eine neue ...

Neue Wissensbeiträge
Windows 10

Windows 10 Fall Creators Update - Neue Funktion Hyper-V Standardswitch kann ggf. Fehler bei Proxy Configs verursachen

Erfahrungsbericht von rzlbrnft vor 5 StundenWindows 101 Kommentar

Hallo Kollegen, Da wir die Gefahr lieben, haben wir bei einigen Usern nun mittlerweile das Creators Update drauf. Einige ...

Sicherheit

TLS-Zertifikat und privater Schlüssel von Microsofts Dynamics 365 geleakt

Information von Penny.Cilin vor 7 StundenSicherheit

Microsoft hat versehentlich das TLS-Zertifikat inklusive dem privaten Schlüssel seiner Business-Anwendung Dynamics 365 geleakt. TLS-Zertifikat und privater Schlüssel von ...

Viren und Trojaner

Deaktivierter Keylogger in HP Notebooks entdeckt

Information von bitcoin vor 1 TagViren und Trojaner2 Kommentare

Ein Grund mehr warum man Vorinstallationen der Hersteller immer blank bügeln sollte Der deaktivierte Keylogger findet sich im vorinstallierten ...

Router & Routing

Lets Encrypt kommt auf die FritzBox

Information von bitcoin vor 1 TagRouter & Routing

In der neuesten Labor-Version der FB7490 integriert AVM unter anderem einen Let's Encrypt Client für Zugriffe auf das Webinterface ...

Heiß diskutierte Inhalte
Netzwerkmanagement
Firefox Profieles im Roaming
gelöst Frage von Hendrik2586Netzwerkmanagement17 Kommentare

Hallo liebe Leute. :) Ich hab da ein kleines Problem, welches anscheinend nicht unbekannt ist. Wir nutzen hier in ...

LAN, WAN, Wireless
Brainstorming, einfachste Option 1 getrenntes LAN (mit WAN zugang)
Frage von 132954LAN, WAN, Wireless13 Kommentare

Hi, folgendes: Wir bekommen eine Glasfaser Leitung, Und das sollte Optional so aussehen: Ein Modem/Router für das WAN, ein ...

Batch & Shell
Trusted Sites für alle User auf dem PC einpflegen
Frage von xXTaKuZaXxBatch & Shell12 Kommentare

Aufgabestellung: Es sollen auf 1 PC (bzw. mehreren PCs) vertrauenswürdige Sites per Powershell eingetragen werden, die für alle User ...

Netzwerkgrundlagen
Hi eine blöde frage. xD
Frage von 132954Netzwerkgrundlagen12 Kommentare

Also: Habe 2012 r2 essentials neuinstalliert, allerdings installiert diese version ja gleich diesen gangen AD kram mit, den hab ...