AGB  ·  Datenschutz  ·  Impressum  







Anmelden
Nützliche Links
Registrieren
Zurück Delphi-PRAXiS Programmierung allgemein Datenbanken Delphi Datensatz über mehrere Tabellen sperren [Vorgehensweise]
Thema durchsuchen
Ansicht
Themen-Optionen

Datensatz über mehrere Tabellen sperren [Vorgehensweise]

Ein Thema von RWarnecke · begonnen am 27. Apr 2010 · letzter Beitrag vom 27. Apr 2010
Antwort Antwort
Benutzerbild von RWarnecke
RWarnecke

Registriert seit: 31. Dez 2004
Ort: Stuttgart
4.408 Beiträge
 
Delphi XE8 Enterprise
 
#1

Datensatz über mehrere Tabellen sperren [Vorgehensweise]

  Alt 27. Apr 2010, 10:19
Datenbank: Firebird • Version: 2.1.3 • Zugriff über: UniDAC
Hallo zusammen,

ich suche einen Weg, einen Datensatz in einer Firebird Datenbank über mehrere Tabellen sperren. Ich habe ca. 10 - 15 Tabellen, worin die Spalte Kundennummer durchgängig ist. Nun möchte ich, das wenn ich einen Kunden auswähle, dessen Kundennummer über alle Tabellen gesperrt wird.

Dabei stellt sich mir die Frage, mache ich das über den Datenbankserver oder über mein Programm und wie mache ich das am besten ?

Edit: Sorry hatte die Datenbank falsch angegeben. Blöde Auto-Vervollständigung
Rolf Warnecke
App4Mission
  Mit Zitat antworten Zitat
borwin

Registriert seit: 14. Sep 2006
Ort: Rostock
72 Beiträge
 
Delphi 2007 Enterprise
 
#2

Re: Datensatz über mehrere Tabellen sperren [Vorgehensweise]

  Alt 27. Apr 2010, 10:28
Zitat:
Datenbank: Firebird Embedded, Version: 2.1.3
Beim der Embedded Version greift immer nur ein User auf die Datenbank. Warum willst Du den Satz dann auf allen Tabellen sperren?

Wenn, dann auf jeden Fall sowas nur auf Seiten des Datenbankservers.

SQL-Technisch musst Du ein Select * from Tabellenname where kundenumer = 1234 LOCK FOR Update machen. (SQL ungeprüft)

Gruß Borwin
  Mit Zitat antworten Zitat
mkinzler
(Moderator)

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

Re: Datensatz über mehrere Tabellen sperren [Vorgehensweise]

  Alt 27. Apr 2010, 10:29
Es reicht den Datensatz in einer Tabelle zu sperren und das andere programmatisch zu machen

BTW: Das Datenmodell scheint mir nicht ganz gut durchdacht zu sein

Die SQL muss so heissen:
Select * from Tabellenname where kundenumer = 1234 FOR Update WITH LOCK;
Markus Kinzler
  Mit Zitat antworten Zitat
Benutzerbild von RWarnecke
RWarnecke

Registriert seit: 31. Dez 2004
Ort: Stuttgart
4.408 Beiträge
 
Delphi XE8 Enterprise
 
#4

Re: Datensatz über mehrere Tabellen sperren [Vorgehensweise]

  Alt 27. Apr 2010, 10:36
Zitat von borwin:
Zitat:
Datenbank: Firebird Embedded, Version: 2.1.3
Beim der Embedded Version greift immer nur ein User auf die Datenbank. Warum willst Du den Satz dann auf allen Tabellen sperren?
Habe ich korrigiert.

Zitat von borwin:
Wenn, dann auf jeden Fall sowas nur auf Seiten des Datenbankservers.
SQL-Technisch musst Du ein Select * from Tabellenname where kundenumer = 1234 LOCK FOR Update machen. (SQL ungeprüft)
Gruß Borwin
Damit sperre ich aber nur in der einen Tabelle den Datenssatz oder ?

Zitat von mkinzler:
Es reicht den Datensatz in einer Tabelle zu sperren und das andere programmatisch zu machen
Nur wie mache ich das, da ich gleichzeitig aber noch haben möchte, dass es trotzdem lesbar ist.
Zitat von mkinzler:
BTW: Das Datenmodell scheint mir nicht ganz gut durchdacht zu sein
Warum sollte das nicht ganz durchdacht sein ?
Rolf Warnecke
App4Mission
  Mit Zitat antworten Zitat
mkinzler
(Moderator)

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

Re: Datensatz über mehrere Tabellen sperren [Vorgehensweise]

  Alt 27. Apr 2010, 10:39
Zitat:
Warum sollte das nicht ganz durchdacht sein ?
Weil die Daten in den Tabellen entweder alle in einer Tabelle stehen könnten oder über Constraints verknüpft sein sollten
Zitat:
Damit sperre ich aber nur in der einen Tabelle den Datenssatz oder ?
http://www.firebirdsql.org/refdocs/l...-withlock.html
Markus Kinzler
  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 19:47 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