Zum Inhalt springen
View in the app

A better way to browse. Learn more.

Fachinformatiker.de

A full-screen app on your home screen with push notifications, badges and more.

To install this app on iOS and iPadOS
  1. Tap the Share icon in Safari
  2. Scroll the menu and tap Add to Home Screen.
  3. Tap Add in the top-right corner.
To install this app on Android
  1. Tap the 3-dot menu (⋮) in the top-right corner of the browser.
  2. Tap Add to Home screen or Install app.
  3. Confirm by tapping Install.

SQL Update mit Schleife?

Empfohlene Antworten

Veröffentlicht

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...

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

ja sry, ganz vergessen. ms sql...

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.

Also wenn ich so eine Tabelle anlege...setzte ich einfach ID auf NOT NULL ...dann klappt es eigentlich immer ohne Probleme!

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

hey, danke streffin das funktioniert wirklich prima. :)

Archiv

Dieses Thema wurde archiviert und kann nicht mehr beantwortet werden.

Configure browser push notifications

Chrome (Android)
  1. Tap the lock icon next to the address bar.
  2. Tap Permissions → Notifications.
  3. Adjust your preference.
Chrome (Desktop)
  1. Click the padlock icon in the address bar.
  2. Select Site settings.
  3. Find Notifications and adjust your preference.