Avatar billede coltau Juniormester
19. november 2021 - 15:33 Der er 3 kommentarer og
1 løsning

Isolationlevel uden transaktionsstyring

Jeg har en tabel med 100000+ records i. De bliver opdateret løbende af mange tråde. Altid kun med simple UPDATE-statements. Ingen transaktionsstyring.

Når jeg så laver en SQL-sætning som denne:
select top 1000 * from tabel
where ID > X
order by ID

Kan der ske ændringer i dataene i den tid det tager SQL-serveren at læse dem?
Kan Isolationslevel have indflydelse på det dataset jeg får ud?
Avatar billede arne_v Ekspert
19. november 2021 - 16:07 #1
Hvorvidt data kan ændre sig afhænger at transaction isolation level.

Med den SELECT og parallele UPDATE's, så vil jeg mene at read uncommitted og read comitted ikke garanterer noget, mens repeatable read og serializable garanterer et konsistent resultat.

Jeg mener at read committed er default i SQL Server.
Avatar billede coltau Juniormester
19. november 2021 - 16:23 #2
arne_v. Det var lige det jeg skulle bekræftes i. Tak.

Jeg kunne også bruge SNAPSHOT eller read commited sammen med denne:
SET READ_COMMITTED_SNAPSHOT ON

Men jeg vil helst bruge den isolationslevel der bruger mindst resourcer.

Jeg skulle bare være sikker på at data kan ændre sig mens de læses med en SQL-sætning.
Avatar billede arne_v Ekspert
19. november 2021 - 16:41 #3
Jeg er ikke SQL Server ekspert så jeg holder mig normalt til de 4 klassiske transaction isolation level.

Snapshot og read committed med read_committed_snapshot=on må svare til serialiable med MVCC.
Avatar billede arne_v Ekspert
19. november 2021 - 16:43 #4
Men jeg kan forstå at dit problem er det omvendte.

Du er ikke bekymret for et inkonsistent resultat fra select - du er bekymret for at update venter p.g.a. select.

Og det skulle være OK med default.
Avatar billede Ny bruger Nybegynder

Din løsning...

Tilladte BB-code-tags: [b]fed[/b] [i]kursiv[/i] [u]understreget[/u] Web- og emailadresser omdannes automatisk til links. Der sættes "nofollow" på alle links.

Loading billede Opret Preview

Log ind eller opret profil

Hov!

For at kunne deltage på Computerworld Eksperten skal du være logget ind.

Det er heldigvis nemt at oprette en bruger: Det tager to minutter og du kan vælge at bruge enten e-mail, Facebook eller Google som login.

Du kan også logge ind via nedenstående tjenester