AGB  ·  Datenschutz  ·  Impressum  







Anmelden
Nützliche Links
Registrieren
Zurück Delphi-PRAXiS Programmierung allgemein Datenbanken InTransaction explizit gesetzt?
Thema durchsuchen
Ansicht
Themen-Optionen

InTransaction explizit gesetzt?

Ein Thema von TurboMagic · begonnen am 22. Feb 2023 · letzter Beitrag vom 24. Feb 2023
Antwort Antwort
TurboMagic

Registriert seit: 28. Feb 2016
Ort: Nordost Baden-Württemberg
2.827 Beiträge
 
Delphi 12 Athens
 
#1

InTransaction explizit gesetzt?

  Alt 22. Feb 2023, 17:52
Datenbank: Firebird • Version: 2.5 • Zugriff über: FireDAC
Hallo,

in meiner Anwendung hab' ich das Problem, dass ich irgendwo prüfe ob
"InTransaction" einer FDConnection true ist und dann eine Exception werfe.

(das ist ja genau genommen FireDAC.Comp.Client.TFDCustomConnection.InTransact ion)

Ich weiß auch welchen anderen Menüpunkt ich vorher in meiner Anwendung aufrufen muss
um das zu triggern, weiß aber nicht warum InTransaction auf true get. Alle Stellen
wo ich StartTransaction aufrufe und die da plausiblerweise reinspucken könnten sind
mit einem Breakpoint versehen und keiner dieser Breakpoints wird erreicht.

Gibt's noch irgendwas anderes, als das was die F1 Hilfe beschreibt, was InTransaction
auf true setzt?

Grüße
TurboMagic
  Mit Zitat antworten Zitat
mkinzler
(Moderator)

Registriert seit: 9. Dez 2005
Ort: Heilbronn
39.851 Beiträge
 
Delphi 11 Alexandria
 
#2

AW: InTransaction explizit gesetzt?

  Alt 22. Feb 2023, 18:07
Durchsuche mal die FireDAC-Quellen, ob darin irgendwo ein Aufruf von .StartTransaction erfolgt.
Markus Kinzler
  Mit Zitat antworten Zitat
hoika

Registriert seit: 5. Jul 2006
Ort: Magdeburg
8.270 Beiträge
 
Delphi 10.4 Sydney
 
#3

AW: InTransaction explizit gesetzt?

  Alt 22. Feb 2023, 18:16
Hallo,
sollte nicht jedes einfache Open eine Transaktion starten,
wenn keine explizite Transaktion gestartet wurde.

Bei IBDAC benutze ich den DBMonitor, dort würde man das sehen.

https://docwiki.embarcadero.com/RADS...chung_(FireDAC)
Heiko
  Mit Zitat antworten Zitat
TurboMagic

Registriert seit: 28. Feb 2016
Ort: Nordost Baden-Württemberg
2.827 Beiträge
 
Delphi 12 Athens
 
#4

AW: InTransaction explizit gesetzt?

  Alt 23. Feb 2023, 16:51
Ich habe Debug DCUs = true eingestellt und in StartTransaction in FireDAC einen breakpoint gesetzt.
Nur wird der nirgends erreicht
Keine Ahnung wie ich rausfinden soll, welche FDQuery das verursacht. Habe mal auf gut Glück eine solche
Query vorher geschlossen, hat aber nix gebracht.
  Mit Zitat antworten Zitat
Benutzerbild von himitsu
himitsu

Registriert seit: 11. Okt 2003
Ort: Elbflorenz
43.163 Beiträge
 
Delphi 12 Athens
 
#5

AW: InTransaction explizit gesetzt?

  Alt 23. Feb 2023, 17:27
Sicher dass die Debuginfos beim Debuggen vom Debugger auch richtig geladen werden?

Hatte auch vor Kurzem so ein Problem.
DebugBreak; oder asm int 3 end; gingen, aber F5 nicht.

Wenn du weißt welche Variable intern den Status für .InTransaction speichert,
könnte man auch mit einem Speicherhaltepunkt auf dessen Änderung reagieren.
Garbage Collector ... Delphianer erzeugen keinen Müll, also brauchen sie auch keinen Müllsucher.
my Delphi wish list : BugReports/FeatureRequests
  Mit Zitat antworten Zitat
TurboMagic

Registriert seit: 28. Feb 2016
Ort: Nordost Baden-Württemberg
2.827 Beiträge
 
Delphi 12 Athens
 
#6

AW: InTransaction explizit gesetzt?

  Alt 23. Feb 2023, 18:32
An irgend einer anderen Stelle im Programm hat er den Breakpoint erreicht.
  Mit Zitat antworten Zitat
Delphi.Narium

Registriert seit: 27. Nov 2017
2.427 Beiträge
 
Delphi 7 Professional
 
#7

AW: InTransaction explizit gesetzt?

  Alt 24. Feb 2023, 17:40
Ich habe Debug DCUs = true eingestellt und in StartTransaction in FireDAC einen breakpoint gesetzt.
Nur wird der nirgends erreicht
Keine Ahnung wie ich rausfinden soll, welche FDQuery das verursacht. Habe mal auf gut Glück eine solche
Query vorher geschlossen, hat aber nix gebracht.
Muss die Transaktion denn von 'ner Query kommen?

Könnte es eventuell möglich sein, das die Connection selbst schon 'ne Transaktion startet, um z. B. Systeminfos aus der Datenbank zu holen?

Schonmal in die MON$TRANSACTIONS geschaut, ob dort was zu 'ner Transaktion zu finden ist?
  Mit Zitat antworten Zitat
Antwort Antwort


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 00:56 Uhr.
Powered by vBulletin® Copyright ©2000 - 2024, Jelsoft Enterprises Ltd.
LinkBacks Enabled by vBSEO © 2011, Crawlability, Inc.
Delphi-PRAXiS (c) 2002 - 2023 by Daniel R. Wolf, 2024 by Thomas Breitkreuz