close

Commit (SQL)

Gå til navigasjon Gå til søk

COMMIT (fra  engelsk  -  "commit, commit") er en SQL-transaksjonskontrolloperatør for vellykket gjennomføring av en transaksjon. Når setningen utføres, blir endringene som er gjort siden begynnelsen av transaksjonen og tidligere ikke var synlige for andre transaksjoner, forpliktet til databasen [1] .

ROLLBACK- setningen brukes til å rulle tilbake alle endringer i en transaksjon . Disse to uttalelsene avslutter eksplisitt transaksjonen [2] .

Oracle

Før du utfører en COMMIT, genererer Oracle angre (angre) og gjør om (redo) datalogger (de kan til og med skrives til disk). Når du utfører COMMIT-setningen, er transaksjonstabellene for redo-poster merket med SCN ( systemendringsnummer , "  systemendringsnummer "), redo-loggbufferne tømmes til disk (på dette stadiet anses transaksjonen som fullført), låser er frigitt, og transaksjonen merkes som fullført [ 1] .

Bruksnotater

Det anbefales å eksplisitt avslutte transaksjoner i applikasjoner ved å bruke kommandoene COMMIT WORK eller ROLLBACK WORK, i samsvar med det første ACID -prinsippet : en transaksjon må være atomisk . Hvis det ikke er laget en eksplisitt transaksjonspost og applikasjonen avsluttes unormalt, vil DBMS tilbakestille den siste uskrevne transaksjonen.

Eksempel

For å legge til en rad i MyTable og lagre endringen, utfør følgende kommandoer:

 BEGYNNE  TRANSAKSJONSARBEID  ; _ INSERT INTO MyTable VALUES ( '50' , 'noen streng' ); FORBINDE ARBEID ;
      
  

Merknader

Litteratur

Lenker