Avatar billede repsak Nybegynder
01. oktober 2003 - 10:33 Der er 6 kommentarer og
1 løsning

Database concurrency

Hvordan sikrer jeg dette med ADO (ODBC)?
Min MySQL database kan tilgåes af mange brugere, så jeg ønsker at sikre at det bliver undersøgt om andre brugere har opdateret et givent felt... (mere klart kan det vist ikke siges :-S)
Jeg mener at jeg skal bruge noget CommandBuilder og/eller Adapter, og jeg har fundet nogle artikler på MSDN, men det giver ikke rigtigt mening for mig. Nogle som har et eksempel?
Avatar billede arne_v Ekspert
01. oktober 2003 - 10:50 #1
Transactions og et passende transaction isolation level (f.eks.
serializable) kan løse nogen problemer.

Andre problemer kræver mere en kodemæssig løsning f.eks. versioning.
Avatar billede repsak Nybegynder
01. oktober 2003 - 11:05 #2
det er nok den versionsmæssige løsning som jeg søger...
Avatar billede arne_v Ekspert
01. oktober 2003 - 11:15 #3
Det er et generelt koncept ikke .NET specifikt.

database record har et felt version

du henter record med SELECT

du kan vente 5-10-15 minutter

gem rettelser implementeres som (pseudo kode):

transaction (serializable) {
  SELECT version from database
  if version from database > version in save request {
      // handle situation
  } else {
      UPDATE database with save request
      UPDATE version in database
  }
}
Avatar billede repsak Nybegynder
01. oktober 2003 - 11:50 #4
ok, jeg forstår ikke helt hvad du mener med den første linje? "transaction (serializable) {"
Vil du have at jeg skal gemme et billede at min Record serialiseret og genindlæse?
Avatar billede arne_v Ekspert
01. oktober 2003 - 12:17 #5
Nej.

Det betyder at det hele skal udføres i en database transaction
og at databasen skal sætte stil "transaction isolation level
serializable" (det er iøvrigt muligt at read committed er nok -
det kan jeg ikke lige gennemskue).
Avatar billede repsak Nybegynder
26. november 2003 - 12:29 #6
svar :-)
Avatar billede arne_v Ekspert
26. november 2003 - 12:33 #7
svar
Avatar billede Ny bruger Nybegynder

Din løsning...

Tilladte BB-code-tags: [b]fed[/b] [i]kursiv[/i] [u]understreget[/u] Web- og emailadresser omdannes automatisk til links. Der sættes "nofollow" på alle links.

Loading billede Opret Preview
Kategori
Kurser inden for grundlæggende programmering

Log ind eller opret profil

Hov!

For at kunne deltage på Computerworld Eksperten skal du være logget ind.

Det er heldigvis nemt at oprette en bruger: Det tager to minutter og du kan vælge at bruge enten e-mail, Facebook eller Google som login.

Du kan også logge ind via nedenstående tjenester