Zum Inhalt springen

Empfohlene Beiträge

Geschrieben

Hey ich habe folgendes Problem und bräuchte mal Hilfe. Meine aktuelle Tabelle sieht so aus...

ID------Name

1-------Sven

2--------franz

NULL-----Klara

NULL-----Katja

Die ID heißt zwar ID aber es ist keine... Fragt micht nicht wieso ich habe die Tabellen nicht aufgebaut...

Nun würde ich gerne mit einer Anweisung daraus folgendes machen

ID------Name

1-------Sven

2--------franz

3--------Klara

4--------Katja

Wenn ich dies nun über ein normales Update mache ist es ja klar das er das nicht korrekt macht.

UPDATE test SET ID = (SELECT MAX(ID)+1 FROM test) WHERE ID IS NULL

Da kommt logischerweise bei den NULL-Werten jeweils ne 3...

Geschrieben

eine Kleinigkeit fehlt bei Deiner Problembeschreibung noch.

Welche DB?

aber generell sollte es mit einer sequence gehen

UPDATE test SET ID = sequence.nextval WHERE ID IS NULL

wobei die Syntax für sequence.nextval eben von Deiner DB abhängt

Geschrieben

Hi,

tja unter MSSQL gibt es so etwas wie eine sequence nicht. Aber mindesten 100 Ansätze Dir Deine eigene zu basteln.

Also entweder Du "kreierst" Deine eigene sequence und nutzt dann diese oder aber Du machst das ganze in einer Prozedur in welcher Du eine Variable mit dem aktuell höchsten Wert füllen kannst und dann diesen innerhalb der Schleife

a) veränderst

B) zum update nutzt

Ich persönlich finde die Idee mit der eigenen Sequence allerdings besser.

Geschrieben

Das is recht einfach gemacht,


declare @max_id int 

select @max_id = max(id) from tabelle 



UPDATE a

SET    id = @max_id + b.ROW_NUM

FROM   tabelle a

       INNER JOIN (

                SELECT ROW_NUMBER() OVER(ORDER BY id) row_num, name

                FROM   tabelle 

            ) as b ON  a.name = b.name

WHERE  a.id IS NULL

der Join sollte normal auf dem primary Key gemacht werden, wenn du da keinen hast, dann ist das recht schlecht. den Join mit dem Subquery würd ich in dem Fall auf allen Feldern der Tabelle machen, ausser der ID, NULL = NULL kannste dir da spaaren. Das Problem ist nämlich, wenn du in der Tabelle z.b. 2 mal den Namen 'Klaus' ohne ID stehen hast, bekommen beide Datensätze die selbe id. da würd ich zur sicherheit hinterher
SELECT COUNT(*) [anzahl], id

FROM tabelle

GROUP BY id

ORDER BY [anzahl] desc

ausführen, damit du sicher bist dass du keine Dubletten drin hast.

Gruß

Sven

Erstelle ein Benutzerkonto oder melde Dich an, um zu kommentieren

Du musst ein Benutzerkonto haben, um einen Kommentar verfassen zu können

Benutzerkonto erstellen

Neues Benutzerkonto für unsere Community erstellen. Es ist einfach!

Neues Benutzerkonto erstellen

Anmelden

Du hast bereits ein Benutzerkonto? Melde Dich hier an.

Jetzt anmelden

Fachinformatiker.de, 2024 by SE Internet Services

fidelogo_small.png

Schicke uns eine Nachricht!

Fachinformatiker.de ist die größte IT-Community
rund um Ausbildung, Job, Weiterbildung für IT-Fachkräfte.

Fachinformatiker.de App

Download on the App Store
Get it on Google Play

Kontakt

Hier werben?
Oder sende eine E-Mail an

Social media u. feeds

Jobboard für Fachinformatiker und IT-Fachkräfte

×
×
  • Neu erstellen...