AGB  ·  Datenschutz  ·  Impressum  







Anmelden
Nützliche Links
Registrieren
Zurück Delphi-PRAXiS Programmierung allgemein Datenbanken Delphi Hilfe beim debugen eines seltsamen Problems

Hilfe beim debugen eines seltsamen Problems

Ein Thema von fisipjm · begonnen am 31. Mär 2022 · letzter Beitrag vom 2. Apr 2022
Antwort Antwort
Benutzerbild von jaenicke
jaenicke

Registriert seit: 10. Jun 2003
Ort: Berlin
10.054 Beiträge
 
Delphi 12 Athens
 
#1

AW: Hilfe beim debugen eines seltsamen Problems

  Alt 31. Mär 2022, 09:15
Tools wie Eurekalog haben auch eine Erkennung, ob die Anwendung hängen bleibt. Nach einem gewissen Timeout kann dann ein Log geschrieben werden, in dem du erkennen kannst, wo es hängt und evtl. auch warum.

In der Ereignisanzeige des Systems ist nichts zu sehen?
Sebastian Jänicke
AppCentral
  Mit Zitat antworten Zitat
fisipjm

Registriert seit: 28. Okt 2013
345 Beiträge
 
Delphi 12 Athens
 
#2

AW: Hilfe beim debugen eines seltsamen Problems

  Alt 31. Mär 2022, 09:30
Leider keine Meldung im Eventlog des Applikationsservers. Auf den SQL Server selbst hab ich keinen Zugriff. Fühlt sich bissel an wie eine Session die hängt. Kann man der Query ein Timeout mit geben?
  Mit Zitat antworten Zitat
Benutzerbild von TigerLilly
TigerLilly

Registriert seit: 24. Mai 2017
Ort: Wien, Österreich
1.251 Beiträge
 
Delphi 12 Athens
 
#3

AW: Hilfe beim debugen eines seltsamen Problems

  Alt 31. Mär 2022, 09:58
Schau mal, ob es in der Datenbank Deadlocks gibt.
https://www.sentryone.com/de/sql-server/sql-deadlock
  Mit Zitat antworten Zitat
fisipjm

Registriert seit: 28. Okt 2013
345 Beiträge
 
Delphi 12 Athens
 
#4

AW: Hilfe beim debugen eines seltsamen Problems

  Alt 31. Mär 2022, 10:28
Schau mal, ob es in der Datenbank Deadlocks gibt.
https://www.sentryone.com/de/sql-server/sql-deadlock
TigerLilly... du bist die beste
Ein select statement blockt mir ein Insert
Das kann die DB scheinbar nicht "auflösen". Ich hab mir jetzt schon bisschen was angeschaut zu "with (nolock)" und updateoptions.lockmode sowie updateoptions.Lockwait aber werd daraus nicht so wirklich schlau, was für mich der richtige Ansatz ist.
Hat da jemand schon Erfahrungen sammeln können?
  Mit Zitat antworten Zitat
taveuni

Registriert seit: 3. Apr 2007
Ort: Zürich
542 Beiträge
 
Delphi 11 Alexandria
 
#5

AW: Hilfe beim debugen eines seltsamen Problems

  Alt 31. Mär 2022, 10:32
wenn Du den SELECT mit NOLOCK ausführst wird die Tabelle nicht gesperrt. Hat den Nachteil dass natürlich eventuell die Ausgabe des SELECTS nicht 100% stimmt.
Die obige Aussage repräsentiert meine persönliche Meinung.
Diese erhebt keinen Anspruch auf Objektivität oder Richtigkeit.
  Mit Zitat antworten Zitat
Benutzerbild von TigerLilly
TigerLilly

Registriert seit: 24. Mai 2017
Ort: Wien, Österreich
1.251 Beiträge
 
Delphi 12 Athens
 
#6

AW: Hilfe beim debugen eines seltsamen Problems

  Alt 31. Mär 2022, 10:34
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
  Mit Zitat antworten Zitat
fisipjm

Registriert seit: 28. Okt 2013
345 Beiträge
 
Delphi 12 Athens
 
#7

AW: Hilfe beim debugen eines seltsamen Problems

  Alt 31. Mär 2022, 11: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
Benutzerbild von Sinspin
Sinspin

Registriert seit: 15. Sep 2008
Ort: Dubai
749 Beiträge
 
Delphi 10.3 Rio
 
#8

AW: Hilfe beim debugen eines seltsamen Problems

  Alt 31. Mär 2022, 13:49
Ich arbeite generell mit NoLock und setzte auf ein eigenes System zum Locken von Datensätzen die bearbeitet werden sollen. Der Nutzer bekommt dann keinen DB Error um die Ohren gehauen wenn ein Record gesperrt ist, sondern eine Vernünftige Meldung und wartet dann einfach mit Posten bis der Lock weg ist.
Stefan
Nur die Besten sterben jung
A constant is a constant until it change.
  Mit Zitat antworten Zitat
Antwort Antwort

Themen-Optionen Thema durchsuchen
Thema durchsuchen:

Erweiterte Suche
Ansicht

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 20:42 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