![]() |
Datenbank: Firebird • Version: 1.5 • Zugriff über: IBDAC
STProcedure und deadlock
Hallo,
ich habe ab und an einen unerklärlichen Deadlock in einer FB Datenbank und vermute, das sich hier eine Stored Procedure "selbst überholt". Die Datenbank ist im Sport eingesetzt. Hier wird z.B. nach dem Ende einer Prüfung Gewinngeld zugeordnet und alle Teilnehmer mit einem Startgeld belastet. Ein Trigger veranlasst, das bei Betragsänderungen auf einem dieser Posten, eine Stored Procedure den Saldo ermittelt und dem Teilnehmer zuordnet. Wenn ich beispielsweise den Gewinn einer Prüfung löschen will, dann reicht dazu ein
SQL-Code:
Jetzt wird die SP n mal aktiviert (z.B. 50 mal).
UPDATE tbl_START SET GEWINN=0 WHERE PRUEFUNG=1
Mir ist nicht ganz klar, wann der Trigger aktiv wird und ob eine Updateanweisung auf das Ende der Stored Procedure/Trigger wartet. Sofort bei Update oder bei Commit) Sonst kann es jetzt wohl vorkommen , das ein Commit erfolgt, wärend in der DB die Berechnung noch läuft. Hier scheint es ab und an zu einem Fehler zu kommen. Ist der Weg der getriggerten Berechnung in diesem Fall richtig oder sollte hier lieber eine rein programmtechnische Lösung gewählt werde? Gruß Peter |
Re: STProcedure und deadlock
Mir fällt hier nur auf, dass die Bedingung durch das SQL nicht zurückgesetzt wird:
SQL-Code:
Wäre es nicht besser so:
UPDATE tbl_START SET GEWINN=0 WHERE PRUEFUNG=1
SQL-Code:
UPDATE tbl_START SET GEWINN=0, PRUEFUNG=0 WHERE PRUEFUNG=1
|
Re: STProcedure und deadlock
Zitat:
|
Re: STProcedure und deadlock
Aha, es war nicht erkennbar dass es sich hierbei um einen Parameter handelt, sah mir aus wie eine Konstante.
|
Alle Zeitangaben in WEZ +1. Es ist jetzt 11:06 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 by Thomas Breitkreuz