[MySQL] in vorhandene Spalte fortlaufende Nummer (unique) einfügen

godlike

Warp drölf
Veteran
Registriert
13 Juli 2013
Beiträge
14.290
Ort
Topkekistan
Ja, steh gerade total auf dem Schlauch. Habe eine Tabelle, brauche dafür jetzt in einer Spalte, welche vorhanden ist, eine fortlaufende Nummer. Möglichst beginnend ab 1000. Unique wäre toll (geht ja eh auch nachträglich), auto_increment ist nicht erwünscht. Kann mir mal schnell einer auf die Sprünge helfen? :confused:

muss ja irgendwie was mit

[src=mysql]UPDATE `tabelle` SET `spalte` = i++[/src]

oder so

[src=mysql]SET @n = 0;
UPDATE `tabelle` SET `spalte` = (@n + 1)[/src]

oder so geben :D

Danke & Gruß

godlike
 
Zuletzt bearbeitet:
Re: [SQL] in vorhandene Spalte fortlaufende Nummer (unique) einfügen

Ohne Gewähr:

DECLARE @zaehler int
SET @zaehler = 999
UPDATE DEINETABELLE
SET @zaehler = DEINESPALTE = @zaehler + 1
 
  • Thread Starter Thread Starter
  • #3
Re: [SQL] in vorhandene Spalte fortlaufende Nummer (unique) einfügen

Da bekomme ich leider

#1064 - You have an error in your SQL syntax; check the manual that corresponds to your MySQL server version for the right syntax to use near 'DECLARE @zaehler int SET @zaehler = 999 UPDATE `tabelle` SET @z' at line 1
 
Re: [SQL] in vorhandene Spalte fortlaufende Nummer (unique) einfügen

Öhm was spricht gegen auto_increment?
 
  • Thread Starter Thread Starter
  • #5
Re: [SQL] in vorhandene Spalte fortlaufende Nummer (unique) einfügen

Dagegen spricht das die Datenbank eigentlich mit IDs aus einem Import gefüllt wird den ich bekomme. Es darf hier nicht zu Überschneidungen kommen da ich sonst evtl doppelte IDs haben könnte. Sprich die IDs, die ich hier vergebe, dienen einem Probelauf. Die Selben werden dann im anderen System, nicht bei uns im Haus, auch keine richtige Datenbank, vergeben und müssen beim nächsten Update dann passen. Sonst wäre das alles kein Problem.

Dachte das sowas schnell zu machen ist sonst lege ich mir da eine andere Lösung parat. Gibt es eine Möglichkeit auto_increment ab einer bestimmten Zahl starten zu lassen?

Die Quelldaten kommen einfach immer von extern. Manche Spalten, die ich für diverse Scripte brauche, lege ich aber hier im Haus an da die nur fürs Web benötigt werden. Es sollte also zu keinen doppelten IDs kommen durch automatisch angelegte IDs. Darum der Stress.

edit: Ok mal ne Test-DB basteln um mir nichts zu zerschießen. Dann probier ich mal

[src=mysql]ALTER TABLE `tabelle` ADD `spalte` INT PRIMARY KEY AUTO_INCREMENT = 1000;[/src]
 
Zuletzt bearbeitet:
Re: [SQL] in vorhandene Spalte fortlaufende Nummer (unique) einfügen

Gibt es eine Möglichkeit auto_increment ab einer bestimmten Zahl starten zu lassen?

ja gibt es, laut doku:
[src=mysql]ALTER TABLE tabelle AUTO_INCREMENT = 100;[/src]

bzw im create:
[src=mysql]CREATE TABLE tabelle (id INT AUTO_INCREMENT PRIMARY KEY, fo VARCHAR(10)) AUTO_INCREMENT = 100; [/src]

hab das allerdings nicht getestet, weil grad kein mysql server zu Hand
 
Re: [SQL] in vorhandene Spalte fortlaufende Nummer (unique) einfügen

Ach, MySQL. Dann vielleicht:


DECLARE @zaehler int;
SET @zaehler = 999;
UPDATE DEINETABELLE;
SET @zaehler = DEINESPALTE = @zaehler + 1 ;
 
Re: [SQL] in vorhandene Spalte fortlaufende Nummer (unique) einfügen

davon bin ich jetzt einfach ausgegangen, weil er mysql im code tag verwendet hat und auto_increment, mysql spezifisch ist, zubindet unter dem Namen :unknown:
 
  • Thread Starter Thread Starter
  • #9
Re: [SQL] in vorhandene Spalte fortlaufende Nummer (unique) einfügen

@Asseon: Das habe ich auch gefunden als ich meinen Beitrag editiert habe. Seltsamerweise funktioniert

ALTER TABLE tabelle ADD spalte INT PRIMARY KEY AUTO_INCREMENT;

bei

ALTER TABLE tabelle ADD spalte INT PRIMARY KEY AUTO_INCREMENT = 1000;

kommt ein Fehler :confused:

edit: Ja Sorry, meine MySQL, hab es im Threadtitel geändert...

edit 2: bekomme auch hier einen Fehler Kapitn:
 
Re: [SQL] in vorhandene Spalte fortlaufende Nummer (unique) einfügen

"AUTO_INCREMENT= " ist eine Tabellen Option.

Heißt muss auf eine Tabelle angewendet werden nicht auf eine spalte.
 
  • Thread Starter Thread Starter
  • #11
Ok, wow das war jetzt verwirrend. Ich mache also erst

[src=mysql]ALTER TABLE tabelle AUTO_INCREMENT = 1000;[/src]

dann erstelle ich mir meine spalte und führe

[src=mysql]ALTER TABLE tabelle ADD spalte INT PRIMARY KEY AUTO_INCREMENT[/src]

So hat es geklappt. Dachte ich kann das gleichzeitig machen. Muss es aber nacheinander machen. Wird Zeit das es Feierabend wird, echt jetzt :m

Vielen Dank euch beiden! :T
 
sry. by MySQL kann ich nur raten, nicht ausprobieren.
DECLARE @zaehler int; ist wohl überflüssig.
 
  • Thread Starter Thread Starter
  • #13
Boar ich dreh noch durch! Jetzt steht die spalte natürlich ganz am Ende. Das ist schlecht da ich die Imports als csv-Dateien bekomme. Die Reihenfolge ist also wichtig. Kann ich eine Spalte im Nachhinein denn verschieben? Oder bei "ADD spalte" eine Position zuweisen?

--- [2015-02-05 16:10 CET] Automatisch zusammengeführter Beitrag ---

Ok, das ging zum Glück gleich :coffee:

[src=mysql]ALTER TABLE tabelle ADD spalte INT PRIMARY KEY AUTO_INCREMENT AFTER spalte2[/src]
 
Du könntest Dir testweise auch einen Trigger schreiben, der nach jedem Insert ausgeführt wird.
Das mit der Eindeutigkeit würde ich über ein unique constraint mit der Spalte lösen. (der primärschlüssel der Tabelle und die fortlaufende Nummer deiner Spalte)

Ggf. musst Du bei einem unique constraint die Eigenheiten Deines Datenmodells beachten. Damit kann man sich einiges kaputt machen :D
 
Zuletzt bearbeitet:
  • Thread Starter Thread Starter
  • #15
Ja, unique ist die Spalte auf jeden Fall. Konnte das aber erst am Schluss machen da ich ja erst die IDs vergeben musste (doppelt leer ist ja auch verboten) ;) Muss das zum Glück ja auch nur ein mal machen, jetzt sollte ja alles passen :)
 
doppelt leer, aka NULL, sollte *eigentlich* kein Problem sein, in postgresql geht das definitiv, es sei denn sie ist mit "NOT NULL" definiert, aber wäre nicht das erste mal, dass mysql sich komisch verhält.
 
Zurück
Oben