AGB  ·  Datenschutz  ·  Impressum  







Anmelden
Nützliche Links
Registrieren
Zurück Delphi-PRAXiS Programmierung allgemein Datenbanken Delphi Dantensätze mit mySQL locken
Thema durchsuchen
Ansicht
Themen-Optionen

Dantensätze mit mySQL locken

Ein Thema von Luckie · begonnen am 28. Jan 2005 · letzter Beitrag vom 29. Jan 2005
Antwort Antwort
Benutzerbild von Luckie
Luckie

Registriert seit: 29. Mai 2002
37.621 Beiträge
 
Delphi 2006 Professional
 
#1

Dantensätze mit mySQL locken

  Alt 28. Jan 2005, 16:42
Ich habe eine mySQL Datenbank, sie läuft zwar lokal aber aus reinem Interesse: Wie sperre ich einen Datensatz damit nicht zwei Clients ihn gleichzeitig ändern können?
Michael
Ein Teil meines Codes würde euch verunsichern.
  Mit Zitat antworten Zitat
Benutzerbild von Marcel Gascoyne
Marcel Gascoyne

Registriert seit: 18. Nov 2003
Ort: Uetersen
271 Beiträge
 
Delphi 2005 Architect
 
#2

Re: Dantensätze mit mySQL locken

  Alt 28. Jan 2005, 16:56
MySQL braucht eigentlich kein Locking, obwohl es keine Transaktionen kennt (zumindest die Standard Tabellen können keine; mit InnoDB sieht das schon anders aus). MySQL arbeitet mit Lese- und Schreibthreads und macht Table Locking (siehe auch diesen Artikel).

Du kannst das Problem auch lösen indem Du einen Versionszähler in Deine Tabelle einbaust:

SQL-Code:
create table kunde (
  id integer not null,
  version integer not null default 1,
  name varchar(60)
)
Bei einem INSERT wird die Version auf 1 gesetzt, bei einem UPDATE machst Du das einfach so:

SQL-Code:
update kunde
set name="Neuer Name"
where id = 100
and version = 1
Dadurch das Du immer auf eine bestimmte Version prüfst kannst Du Konflikte mit anderen Anwendungen vermeiden.

Gruß,
Marcel
Marcel Gascoyne
Der Fehler sitzt immer vor der Tastatur
  Mit Zitat antworten Zitat
Benutzerbild von Mamphil
Mamphil

Registriert seit: 17. Jul 2004
Ort: Garching b. München
149 Beiträge
 
Delphi 7 Professional
 
#3

Re: Dantensätze mit mySQL locken

  Alt 29. Jan 2005, 15:48
Hi!

Musst du die Version nicht noch hochzählen?
SQL-Code:
update kunde
set name="Neuer Name", version = version + 1
where id = 100
and version = 1
Mamphil
The laws of physics are the canvas God laid down on which to paint his masterpiece. “Leonardo Vetra” in Dan Brown’s “Angels & Demons”
  Mit Zitat antworten Zitat
Benutzerbild von Luckie
Luckie

Registriert seit: 29. Mai 2002
37.621 Beiträge
 
Delphi 2006 Professional
 
#4

Re: Dantensätze mit mySQL locken

  Alt 29. Jan 2005, 15:49
Zitat von Marcel Gascoyne:
MySQL braucht eigentlich kein Locking, obwohl es keine Transaktionen kennt (zumindest die Standard Tabellen können keine; mit InnoDB sieht das schon anders aus). MySQL arbeitet mit Lese- und Schreibthreads und macht Table Locking (siehe auch diesen Artikel).
Ok, danke. Dann hat sich das erledigt.
Michael
Ein Teil meines Codes würde euch verunsichern.
  Mit Zitat antworten Zitat
Benutzerbild von Marcel Gascoyne
Marcel Gascoyne

Registriert seit: 18. Nov 2003
Ort: Uetersen
271 Beiträge
 
Delphi 2005 Architect
 
#5

Re: Dantensätze mit mySQL locken

  Alt 29. Jan 2005, 18:13
Zitat von Mamphil:
Musst du die Version nicht noch hochzählen?
Oops, natürlich

Gruß,
Marcel
Marcel Gascoyne
Der Fehler sitzt immer vor der Tastatur
  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 12:04 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