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.

Select max(id)+1

Empfohlene Antworten

Hallo,

ich arbeite mit einer Oracle Datenbank und benutze zum hochzählen meiner fortlaufenden ID den Befehl Select max(id) from tabelle. Diese Speicher ich dann in einer Variable und zähle dann um eins hoch und schreib den neuen Datensatz zurück in die Datenbank.

Jetzt habe ich gelesen das dies schlecht sein soll und man es so nicht machen sollte. Nur warum?

Weil max(id) immer alle Datensätze durch jagt, d.h. man braucht immer länger um das max() auszuführen und irgendwann kommt man an den Punkt wo max() noch ausgeführt wird und schon die nächste Anfrage vor der Tür steht, also du 2 mal den selben Wert bekommst und das ist bekanntlich nicht zulässig für ein Primärschlüssel.

Deswegen sollte man das mit einer Sequenz machen und dazu einen Trigger.

Die Schwierigkeit daran ist dass wenn Du Datensätze löscht, kann es in Deinem Fall ebenso zu doppelten IDs kommen, was letztlich einen Fehler verursacht. Ich verstehe jedoch nicht ganz warum Du die ID manuell zählst. Wenn es doch mit Increment / Sequence bedeutend einfacher und problemloser funktioniert.

Archiv

Dieses Thema wurde archiviert und kann nicht mehr beantwortet werden.

Konto

Navigation

Suchen

Suchen

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.