AGB  ·  Datenschutz  ·  Impressum  







Anmelden
Nützliche Links
Registrieren
Zurück Delphi-PRAXiS Programmierung allgemein Datenbanken Delphi Versionierung von Datensätzen in Firebird
Thema durchsuchen
Ansicht
Themen-Optionen

Versionierung von Datensätzen in Firebird

Ein Thema von TheFrog · begonnen am 13. Jul 2009 · letzter Beitrag vom 13. Jul 2009
Antwort Antwort
TheFrog

Registriert seit: 24. Mär 2009
145 Beiträge
 
Delphi 11 Alexandria
 
#1

Versionierung von Datensätzen in Firebird

  Alt 13. Jul 2009, 13:39
Datenbank: Firebird • Version: 1.5 • Zugriff über: IBX-Komponenten
Mich beschäftigt schon länger eine Frage Firebird betreffend.

Ich habe mal gehört, dass FireBird (und wahrscheinlich auch Interbase) intern pro Datensatz verschiedene Versionen hält (Versioning). Diese dienen wohl einem Rollback, usw.

Nun meine Frage:

Ist es möglich, auf diese Versionen irgendwie zuzugreifen? D.h. konkret, ich würde gerne wissen, wann was an einem bestimmten Datensatz geändert wurde.

Ich merke mir zwar pro Datensatz wann dieser von wem angelegt wurde, auch merke ich mir, wann dieser von wem das letzte mal geändert wurde, aber leider habe ich keine Informationen, was geändert wurde.

Vielen Dank, Hans.
  Mit Zitat antworten Zitat
Blup

Registriert seit: 7. Aug 2008
Ort: Brandenburg
1.477 Beiträge
 
Delphi 12 Athens
 
#2

Re: Versionierung von Datensätzen in Firebird

  Alt 13. Jul 2009, 14:00
Nein, die Versionen werden nur so lange gehalten, bis die letzte Transaktion beendet wird, die mit dieser Version des Datensatzes oder einer älteren arbeitet.

Man kann sich aber Trigger und Protkolltabellen anlegen, die jede Änderung aufzeichnen.
IBExpert kann diese sogar vollautomatisch erstellen (bei der entsprechenden Tabelle auf den Reiter Logging wechseln).
  Mit Zitat antworten Zitat
hoika

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

Re: Versionierung von Datensätzen in Firebird

  Alt 13. Jul 2009, 14:08
Hallo,

das ist korrekt.
Wenn du wissen möchtest, was geändert wurde,
musst du das entweder:

1. selber programmieren (clientseitig)

2. per Trigger protokollieren lassen (serverseitig)
Ein Ansatz für die Datenstruktur wäre hier:
Replikation

Hier kommen dann auch die neue CURRENT_USER Variable zum Tragen
(oder gab es die erst ab FB2.0 ?)


Ansatz 2 ist etwas aufwendiger, aber flexibler und schneller (weil serverseitig).


Heiko
Heiko
  Mit Zitat antworten Zitat
TheFrog

Registriert seit: 24. Mär 2009
145 Beiträge
 
Delphi 11 Alexandria
 
#4

Re: Versionierung von Datensätzen in Firebird

  Alt 13. Jul 2009, 14:57
Das war zwar was ich vermutet habe, aber nicht hören wollte! Irgendwie habe ich auf eine andere Lösung gehofft.

Die Trigger-Variante habe ich bisher gescheut, weil ich das doch sehr hohe Datenaufkommen fürchte! Ich werde mich damit aber mal näher beschäftigen.


Vielen Dank auf jeden Fall für die Antworten.

Hans.
  Mit Zitat antworten Zitat
hoika

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

Re: Versionierung von Datensätzen in Firebird

  Alt 13. Jul 2009, 15:00
Hallo,

Zitat:
sehr hohe Datenaufkommen
Das kommt auf die Trigger an,
du kannst ja bestimmte Datenfelder/Tabellen weglassen.


Heiko
Heiko
  Mit Zitat antworten Zitat
TheFrog

Registriert seit: 24. Mär 2009
145 Beiträge
 
Delphi 11 Alexandria
 
#6

Re: Versionierung von Datensätzen in Firebird

  Alt 13. Jul 2009, 15:26
Hallo Heiko,

das ist richtig, ich könnte hier selektiv vorgehen, aber dann läßt man sicher die Datenfelder weg, welche einem dann doch fehlen.

Aber Du hast insofern recht, dass gewisse Verwaltungfelder, wie z.B. das letzte Änderungsdatum, usw. nicht mit aufgenommen werden müssen.

Ich werde mir die Sache auf jeden Fall mal durch den Kopf gehen lassen (auch die Möglichkeit von IBExpert, diese Protokollierung autmatisch anlegen zu lassen).

Hans.
  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 17:30 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