AGB  ·  Datenschutz  ·  Impressum  







Anmelden
Nützliche Links
Registrieren
Zurück Delphi-PRAXiS Programmierung allgemein Datenbanken Delphi [oracle] fehler bei "auto-increment" mit trigger & seque
Thema durchsuchen
Ansicht
Themen-Optionen

[oracle] fehler bei "auto-increment" mit trigger & seque

Ein Thema von s.h.a.r.k · begonnen am 22. Aug 2008 · letzter Beitrag vom 22. Aug 2008
 
Elvis

Registriert seit: 25. Nov 2005
Ort: München
1.909 Beiträge
 
Delphi 2010 Professional
 
#7

Re: [oracle] fehler bei "auto-increment" mit trigg

  Alt 22. Aug 2008, 09:02
Oracle Sequences besitzen einen Cache (default ist IMO 20).
Wenn eine Session die Sequence zm ersten Mal anfasst, wird diese dann X weitere Werte in den Sessionspeicher laden.
Wenn du danach mit einer 2. Session darauf zugreifst könnte das unterschiedlich sortierte IDs ergeben.
Außerdem unterliegen Sequences niemals Transaktionen. Die Änderungen sind immer sofort für alle sichtbar (muss auch, sonst gäbe es doppelte IDS )
  • Session #1 greift auf die Sequence zu
    • Wert: 1
    • Sequence wird um 20 erhöht.
  • Session #2 greift auf die Sequence zu
    • Wert: 21
    • Sequence wird um 20 erhöht.
  • Session #2 greift wieder auf die Sequence zu
    • Wert: 22
    • Sequence wird nicht um 20 erhöht, hat ja noch weitere 18.
  • Session #1 greift wieder auf die Sequence zu
    • Wert: 2
    • Sequence wird nicht um 20 erhöht, hat ja noch weitere 18.
  • ...
Wenn mehrere Transaktionen parallel laufen, wird es ständig solche Überschneidungen geben.
Die Alternative wäre ein kleinerer Cache (Minimum ist IMO 2), aber das wäre eher dumm, da das ständige Sperren der Sequence Zeit kosten würde, die je nach Datendurchsatz durchaus bemerkbar wäre.
Robert Giesecke
I’m a great believer in “Occam’s Razor,” the principle which says:
“If you say something complicated, I’ll slit your throat.”
  Mit Zitat antworten Zitat
 


Forumregeln

Es ist dir nicht erlaubt, neue Themen zu verfassen.
Es ist dir nicht erlaubt, auf Beiträge zu antworten.
Es ist dir nicht erlaubt, Anhänge hochzuladen.
Es ist dir nicht erlaubt, deine Beiträge zu bearbeiten.

BB-Code ist an.
Smileys sind an.
[IMG] Code ist an.
HTML-Code ist aus.
Trackbacks are an
Pingbacks are an
Refbacks are aus

Gehe zu:

Impressum · AGB · Datenschutz · Nach oben
Alle Zeitangaben in WEZ +1. Es ist jetzt 19:09 Uhr.
Powered by vBulletin® Copyright ©2000 - 2025, Jelsoft Enterprises Ltd.
LinkBacks Enabled by vBSEO © 2011, Crawlability, Inc.
Delphi-PRAXiS (c) 2002 - 2023 by Daniel R. Wolf, 2024-2025 by Thomas Breitkreuz