AGB  ·  Datenschutz  ·  Impressum  







Anmelden
Nützliche Links
Registrieren
Zurück Delphi-PRAXiS Programmierung allgemein Datenbanken Delphi Zugriff auf einen Datensatz sperren oder freigeben
Thema durchsuchen
Ansicht
Themen-Optionen

Zugriff auf einen Datensatz sperren oder freigeben

Ein Thema von Eppos · begonnen am 3. Mär 2008 · letzter Beitrag vom 4. Mär 2008
Antwort Antwort
Eppos

Registriert seit: 7. Aug 2006
Ort: Heilbronn
523 Beiträge
 
Delphi 11 Alexandria
 
#1

Zugriff auf einen Datensatz sperren oder freigeben

  Alt 3. Mär 2008, 17:05
Datenbank: Firebird • Version: 1.5 • Zugriff über: bde
Hallo zusammen,

suche noch Anregungen für die Sperrungen eines Datensatzes, wenn ein Benutzer den Datensatz im Zugriff hat.

Also kurze Erklärung:

Benutzer "A" und Benutzer "B" arbeiten mit der Tabelle "XYZ"
Benutzer "A" öffnet den Datensatz "1".
Benutzer "B" öffnet eine Sekunde später den gleichen Datensatz. (Was er aber eigentlich nicht darf, da er gesperrt sein sollte)

Wie handhabt Ihr dieses Problem?
Gibt es da eine möglichkeit bei der Firebird-DB diese Problem zu handhaben?

Ich kenne schon eine Lösung, die dan einen benutzer bei diesem Datensatz hinterlegt, und ich das bei den anderen Benutzer immer abprüfe, ob dieser Datensatz im Zugriff ist oder nicht. Aber was ist wenn die Anwendung abbricht...?!

Vielen Dank!

Eppos
  Mit Zitat antworten Zitat
mkinzler
(Moderator)

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

Re: Zugriff auf einen Datensatz sperren oder freigeben

  Alt 3. Mär 2008, 18:04
Locking ist unter FB dank des Multi Generatoren Architektur (MGA) oft nicht notig. Sonst kann man natürlich Datensätze auch locken
Markus Kinzler
  Mit Zitat antworten Zitat
bluesbear

Registriert seit: 14. Dez 2005
Ort: Hahnstätten
355 Beiträge
 
Delphi 2007 Enterprise
 
#3

Re: Zugriff auf einen Datensatz sperren oder freigeben

  Alt 3. Mär 2008, 18:57
Zitat:
Datenbank: Firebird, Version: 1.5, Zugriff über: bde
Zugriff über BDE? Grundsätzlich gebe ich mkinzler recht, aber ob die BDE das hinbekommt? Habe ich noch nicht ausprobiert, und werde es auch nicht tun.
Klaus M. Hoffmann
  Mit Zitat antworten Zitat
hoika

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

Re: Zugriff auf einen Datensatz sperren oder freigeben

  Alt 4. Mär 2008, 12:34
Hallo,

mit Bordmitteln geht das wie folgt,
Bsp. geht davon aus, dass der primkey id heisst und der aktuelle Record id=5 ist

A: starttransaction
update table1 set id=5 where id=5

B: starttransaction
update table1 set id=5 where id=5 <- Fehler

A hält die transaktion offen, und solange er kein rollback oder commit macht,
kommt keiner an den Datensatz ran.

Nachteil: offene Transaktion

(http://entwickler-forum.de/archive/i...p/t-18455.html)


Andere Rangehensweise:
Vorm Ändern wird die ID in eine Sperr(Lock)Tabelle geschrieben,
klappt das, kann es weitergehen.
Klappt es nicht (unique index), ist gerade eine dran am Ändern.
Die Sperre wird mit einem TimeStamp geschrieben
und über Thread / Time vom Client (deiner App) ständig aktualisiert.

Vor dem Versuch, was einzutragen, werden "alte Sperren" entfernt,
z.B. die > 15min.
Ds wären dann die von abgstürzten Apps.

Vorteil :
Du kannst sagen, Datensatz wird gerade bearbeitet von XXX (User packst du mit in die Locktable),
seit (TimeStamp).

Nachteil: Programmieraufwand.
Es wird mind IBX benötigt, um readcommited als Transaktions-Modus einzustellen
(kann das die BDE ?)

Die Locktable sieht etwas so aus
Id: AutoInc Generator)
TableId / TableName
KeyField Integer
Gen_Date TimeStamp
UserId / UserName


In einer alten Entwickler (6-2003) war das mal als Bsp
"Ich sperre, also bin ich" drin.

Heiko
Heiko
  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 18:22 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