AGB  ·  Datenschutz  ·  Impressum  







Anmelden
Nützliche Links
Registrieren
Zurück Delphi-PRAXiS Programmierung allgemein Datenbanken Delphi Edit bei mehreren Benutzern
Thema durchsuchen
Ansicht
Themen-Optionen

Edit bei mehreren Benutzern

Ein Thema von stefan681 · begonnen am 23. Jun 2005 · letzter Beitrag vom 23. Jun 2005
Antwort Antwort
stefan681

Registriert seit: 16. Jun 2005
18 Beiträge
 
#1

Edit bei mehreren Benutzern

  Alt 23. Jun 2005, 10:18
Datenbank: Advantage • Zugriff über: TDataSet
Hallo,

ich möchte beim Zufriff auf einen Datensatz wissen, ob ein anderer User diesen
schon zum edit geöffnet hat. Den Code dafür habe ich schon geschrieben.

Meine Frage ist aber:
Ich wollte diesen Code in dem Ereignis 'BeforeEdit' der Tabelle verwenden.
Wenn jetzt dieser Code sagt, der Datensatz ist gesperrt, würde die Routine 'BeforEdit'
automatisch weitermachen, und so doch eine Fehlermeldung des Datenbank-Servers anzeigen.
Oder kann ich diese Routine irgendwie verlasen?

Danke.

Stefan
  Mit Zitat antworten Zitat
Benutzerbild von Sharky
Sharky

Registriert seit: 29. Mai 2002
Ort: Frankfurt
8.251 Beiträge
 
Delphi 2006 Professional
 
#2

Re: Edit bei mehreren Benutzern

  Alt 23. Jun 2005, 10:25
Hai Stefan,

es müsste doch reichen ein DataSet.Cancel einzubauen oder?
Stephan B.
"Lasst den Gänsen ihre Füßchen"
  Mit Zitat antworten Zitat
Benutzerbild von Catbytes
Catbytes

Registriert seit: 7. Sep 2002
Ort: Heckendalheim
353 Beiträge
 
Delphi XE5 Enterprise
 
#3

Re: Edit bei mehreren Benutzern

  Alt 23. Jun 2005, 10:27
Langt nicht ein einfaches:

Delphi-Quellcode:
procedure TForm1.ADOQuery1BeforeEdit(DataSet: TDataSet);
begin
if Datensatzgesperrt then
Exit;
SonstigeRoutinen...
end;
???
Catbytes
  Mit Zitat antworten Zitat
Benutzerbild von Jelly
Jelly

Registriert seit: 11. Apr 2003
Ort: Moestroff (Luxemburg)
3.741 Beiträge
 
Delphi 2007 Professional
 
#4

Re: Edit bei mehreren Benutzern

  Alt 23. Jun 2005, 11:32
Zitat von Sharky:
es müsste doch reichen ein DataSet.Cancel einzubauen oder?
Da im BeforeEdit Ereignis der Datensatz noch nicht im Editiermodus ist. wird ein Cancel nicht viel bringen. Es sollte aber klappen das Ganze ins AfterEdit Ereignis zu verlagern.
  Mit Zitat antworten Zitat
stefan681

Registriert seit: 16. Jun 2005
18 Beiträge
 
#5

Re: Edit bei mehreren Benutzern

  Alt 23. Jun 2005, 12:58
Aber beim Ater Edit ist es "schon zu spät", da Edit schon ausgelöst
wurde und dann der Datenbank-Server die Fehlermeldung erzeugt.

Wie macht ihr das denn bei mehreren Benutzer sicher stellen,
das nur ein User den Datensatz bearbeitet?
  Mit Zitat antworten Zitat
Benutzerbild von Jelly
Jelly

Registriert seit: 11. Apr 2003
Ort: Moestroff (Luxemburg)
3.741 Beiträge
 
Delphi 2007 Professional
 
#6

Re: Edit bei mehreren Benutzern

  Alt 23. Jun 2005, 13:13
Zitat von stefan681:
Aber beim Ater Edit ist es "schon zu spät", da Edit schon ausgelöst
wurde und dann der Datenbank-Server die Fehlermeldung erzeugt.
Das hängt dann aber davon ab, wie du den Server konfigurierst. Kuck dir in dem Zusammenhang mal TransIsolation Level an.
  Mit Zitat antworten Zitat
Benutzerbild von Stevie
Stevie

Registriert seit: 12. Aug 2003
Ort: Soest
4.009 Beiträge
 
Delphi 10.1 Berlin Enterprise
 
#7

Re: Edit bei mehreren Benutzern

  Alt 23. Jun 2005, 13:19
Hi,

wenn ich mich recht erinner, müsste ein Delphi-Referenz durchsuchenAbort im BeforeEdit reichen, um auch das Edit an sich zu stoppen.
Allerdings halte ich diese Vorgehensweise in deinem Fall nicht für die beste, denn so wird der Benutzer nicht darüber informiert, dass und warum der Satz nicht gespeichert werden kann. Ich würde eher vorschlagen, global (im Delphi-Referenz durchsuchenApplication.OnException) diese spezielle Execption, die der Server liefert, abzufangen und in eine für den Benutzer verständliche Nachricht zu verarbeiten.

MfG
Stevie
Stefan
“Simplicity, carried to the extreme, becomes elegance.” Jon Franklin

Delphi Sorcery - DSharp - Spring4D - TestInsight
  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 09:49 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