Einzelnen Beitrag anzeigen

fisipjm

Registriert seit: 28. Okt 2013
298 Beiträge
 
#8

AW: Hilfe beim debugen eines seltsamen Problems

  Alt 31. Mär 2022, 12:05
Um Datenkonsistenz zu wahren, sperrt der SQL Sevrer Sätze bzw Pages bzw Tables, das nennt sich dann Lock Escalation, weil uU Sätze gesperrt sind, die mit der Transaktion gar nichts zu tun haben. Ich nutze in unseren Programmen bei allen selects "with (nolock)" + hatte noch nie - auch in stark concurrenten Umgebungen Probleme, Aber das waren auch immer Daten, wo viel mehr gelesen als geschrieben wurde.

Manche sagen, with nolock wäre bad practice. Aber - sieh oben - das hängt davon ab.

https://www.sentryone.com/blog/aaron...ock-everywhere
https://www.sqlshack.com/understandi...l-server-2017/
https://stackoverflow.com/questions/...t-bad-practice
Danke für die Hinweise, da ich innerhalb der Klasse immer über die geleiche Connection gehe, habe ich das ganze jetzt so gelöst:
Delphi-Quellcode:
DataConnection.UpdateOptions.LockMode := lmPessimistic;
    DataConnection.UpdateOptions.LockWait := True;
Das sind 2 Zeilen mehr Code und scheint zu funktionieren. Jedes SQL Statement um ein
Code:
With (NoLock)
zu ergänzen wäre deutlich mehr Aufwand. Scheint aktuell mal zu laufen. merci
  Mit Zitat antworten Zitat