AGB  ·  Datenschutz  ·  Impressum  







Anmelden
Nützliche Links
Registrieren
Zurück Delphi-PRAXiS Programmierung allgemein Datenbanken Delphi Record Locking mit Delphi
Thema durchsuchen
Ansicht
Themen-Optionen

Record Locking mit Delphi

Ein Thema von GreenHorn3600 · begonnen am 24. Jun 2007 · letzter Beitrag vom 25. Jun 2007
Antwort Antwort
Seite 2 von 2     12   
bttb930

Registriert seit: 6. Okt 2003
372 Beiträge
 
#11

Re: Record Locking mit Delphi

  Alt 24. Jun 2007, 22:41
Ihr diskutiert zuviel was ihr wollt. Es wurde nach Locking gefragt, und nicht nach einer Abstimmung wer für und wer gegen Access ist.

Wie hier ja schon durchschimmert, musst du tatsächlich als Entwickler alles selber machen. Es gibt da mehrere Möglichkeiten:

- Datensatz lesen. Er ist nicht gelockt.
- Datensatz in der Anwendung ändern.
- Datensatz soll gespeichert werden - dazu per Dataset (TQuery oder TTable) öffnen für Edit. Dadurch wird er gelockt. Jetzt nicht direkt schreiben sondern erstmal prüfen: Sind da die gleichen Daten drin wie du gelesen hast? Falls ja: Daten schreiben und speichern (Post). Falls nein: Meldung an Benutzer oder was-weiß-ich und schließen.

Alternativ - da hast du weniger zu tun, nur legt ein anwender dann alle anderen still:

- Connection öffnen
- Transaktion starten. Bei MSSQL-Server würdest Du REPEATABLE READ nutzen.
- Datensätze öffnen, wenigstens einen beschreiben (dadurch ist dann die gesamte tabelle für alle anderen benutzer gesperrt).
- Datensätze in der anwendung verändern lassen und dann schreiben.
- Transaktion beenden.

Finde ich persönlich sehr schlechte lösung. Wäre aber wohl das, wonach du gefragt hast.

Dritte Alternative, die auch schon oben angegeben wurde, aber nicht in einzelschritten:

- Datensätze lesen und jeweils sperren indem du in eine andere Locking-Tabelle schreibst, wer welchen datensatz wann gesperrt hat. Beim lesen prüfst du natürlich, dass der zu lesende datensatz nicht schon gesperrt ist.
- datensätze verändern und speichern
- lcoking-eintrag entfernen.

Problem wurde oben auch genannt: was ist wenn der rechner abstürzt. Dazu könnte man beispielsweise die oben erwähnte 10-min-regel machen. Eine ideale lösung gibt es dafür nicht.

Die unterschiede sind:
- ganz oben lockst du gar nichts und prüfst nur ob die daten in der zewichenzeit verändert wurden. Ggf wird der anwender eine "wurde verändert"-meldung bekommen.
- in der mitte sperrst du so restriktiv, dass dem anwender der da sperrt nichts passieren kann, alle anderen in dem moment aber nicht arbeiten können. das ist natürlich in einer mehrbenutzerumgebung ein ko-kriterium.
- und unten sperrst du indirekt durch die locking-tabelle, die du selbst verwaltest. der nachteil ist, dass bei rechner-absturz evtl. datensätze erstmal nicht mehr erreichbar sind (für die anderen). aber diesen nachteil kann man wie gesagt ganz gut lösen.

also nichts mit automatisch.

PS: um auch nochmal was zu access zu sagen: Leute die schreiben: "Access ist scheiße. Hab nie damit gearbeitet, ist aber so!"... was soll man denn von denen halten? Wir haben alle unsere vorurteile gegen microsoft, aber ich habe viel mit access gearbeitet und muss sagen: Wenn man diese DB richtig einsetzt, dann ist sie wirklich sehr sehr gut! Sehr stabil, mir ist noch nie eine DB kaputt gegangen, sehr performant und so weiter. Es ist nunmal eine Desktop-Datenbank, die hat ihre Grenzen. Aber die meisten anwendungen können mit diesen grenzen gut leben (wer verwaltet schon 60 Mio Kunden). Und auch in Mehrbenutzerumgebungen hatte ich mit Access nie Probleme. Das wirkliche Problem bei Access ist, dass es relativ leicht ist, sich dort was zurechtzuklicken. Daraus entstehen dann datenbanken, die nicht wartbar sind, weil die ersteller keine ahnung hatten. Da ist das problem aber nicht access, sondern die ersteller der dbs sind das problem. Also schimpft nicht immer gegen access solange ihr die db nicht wirklich kennt. Euer geschimpfe zeigt nur eure ignoranz und eigentlich zeigt ihr damit nur, dass ihr euer fähnchen in den wind haltet.
  Mit Zitat antworten Zitat
majmarcus

Registriert seit: 24. Jul 2005
Ort: Neulengbach
3 Beiträge
 
RAD-Studio 2009 Pro
 
#12

Re: Record Locking mit Delphi

  Alt 25. Jun 2007, 11:26
[quote="bttb930"]
- Datensatz lesen. Er ist nicht gelockt.
- Datensatz in der Anwendung ändern.
- Datensatz soll gespeichert werden - dazu per Dataset (TQuery oder TTable) öffnen für Edit. Dadurch wird er gelockt. Jetzt nicht direkt schreiben sondern erstmal prüfen: Sind da die gleichen Daten drin wie du gelesen hast? Falls ja: Daten schreiben und speichern (Post). Falls nein: Meldung an Benutzer oder was-weiß-ich und schließen./quote]

Hallo, geht besonders einfach wenn ein extra Feld (not nullable) bspw. ("rowversion") in jeder Tabelle mit dabei ist und bei jedem update der Zeile hochgezählt wird. Damit kann schnell und einfach ein konkurierendes Update erfaßt und darauf wie auch immer reagiert werden.

Initialisieren beim Insert mit 0 wäre dabei hilfreich
  Mit Zitat antworten Zitat
alzaimar
(Moderator)

Registriert seit: 6. Mai 2005
Ort: Berlin
4.956 Beiträge
 
Delphi 2007 Enterprise
 
#13

Re: Record Locking mit Delphi

  Alt 25. Jun 2007, 16:05
Zitat von bttb930:
Ihr diskutiert zuviel was ihr wollt. Es wurde nach Locking gefragt, und nicht nach einer Abstimmung wer für und wer gegen Access ist.
Das hat nix mit Duskussion zu tun: Es ist ein noch nicht mal gut gemeinter Rat, sondern einfach eine Aufschrei: "LASS DIE FINGER VON ACCESS BEI MEHR ALS 1 ANWENDER!eins!!elf'
"Wenn ist das Nunstruck git und Slotermeyer? Ja! Beiherhund das Oder die Flipperwaldt gersput!"
(Monty Python "Joke Warefare")
  Mit Zitat antworten Zitat
mkinzler
(Moderator)

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

Re: Record Locking mit Delphi

  Alt 25. Jun 2007, 16:14
Außerdem heißt der Thread ja "Access oder auch was anderes"
Markus Kinzler
  Mit Zitat antworten Zitat
hoika

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

Re: Record Locking mit Delphi

  Alt 25. Jun 2007, 16:26
Hallo,

aus "habe ich gehört und gesehen"
20 gleichzeitige Nutzer bremsen Access extrem aus.
Absturz, Exclusiv reingehen, reparieren, weiter

Ein Umstieg auf SQL-Server (per Access Project)
gehob das Problem.


Zu den Locks und den 10 Minuten.
Führe eine Locking-Tabelle mit, in der UserId, Tabelle (Id), zu lockender PrimKey
und Datum/Uhrzeit) mitgelockt werden.
Und nu kommst !!
Per Timer oder Thread werden die aktuellen Locks aufgefrischt,
also Datum/Uhrzeit aktualisiert.
Schmiert das Programm ab, "verfällt" die Sperre irgendwann (z.B. nach 5 Minuten)

Beim Start der App oder beim Setzen irgendeines Locks
werden alle Locks < X Min gelöscht (am besten per stored procedure).
Die Tabelle hat den Vorteil, dass man auch eine Meldung ala
"Datensatz wird gerade bearbeitet von XXX seit YYY"

Zum Locken allgemein.
Ein Locken bei Mehrbenutzerbetrieb ist notwendig.
Wenn ich einen Kunden bearbeiten will und verhindern
will, dass zum gleichen Zeitpunkt das jemand anders soll,
was bliebt mit anderes übrig ?
Das Locken hat hier natürlich nichts mit den DB-Locksbei konkurrierenden
Zugriffen zu tun, sondern ein lock innerhalb der Anwendung.


Heiko
Heiko
  Mit Zitat antworten Zitat
Antwort Antwort
Seite 2 von 2     12   


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 01:18 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