Manajemen Basis Data Pertemuan 4 Matakuliah: M0264/Manajemen Basis Data Tahun: 2008.

Post on 15-Jan-2016

225 views 0 download

Transcript of Manajemen Basis Data Pertemuan 4 Matakuliah: M0264/Manajemen Basis Data Tahun: 2008.

Manajemen Basis DataPertemuan 4

Matakuliah : M0264/Manajemen Basis Data

Tahun : 2008

Bina Nusantara

• Concurency Control• Advanced Transaction Models• Transaction Support (Transaksi Pendukung pada SQL)

Objectives

Bina Nusantara

• Meaning of serializability.• How locking can ensure serializability.• Deadlock and how it can be resolved.• How timestamping can ensure serializability.• Optimistic concurrency control.• Granularity of locking.

Concurency Control

Bina Nusantara

Concurency Control

• Process of managing simultaneous operations on the database without having them interfere with one another.

• Prevents interference when two or more users are accessing database simultaneously and at least one is updating data.

• Although two transactions may be correct in themselves, interleaving of operations may produce an incorrect result.

Bina Nusantara

Concurency Control

• Three examples of potential problems caused by concurrency: – Lost update problem.– Uncommitted dependency problem.– Inconsistent analysis problem.

Bina Nusantara

Advanced Transaction Models

• Protocols considered so far are suitable for types of transactions that arise in traditional business applications, characterized by:– Data has many types, each with small number of instances.– Designs may be very large.– Design is not static but evolves through time. – Updates are far-reaching.– Cooperative engineering.

Bina Nusantara

Advanced Transaction Models

• May result in transactions of long duration, giving rise to following problems:– More susceptible to failure - need to minimize amount of work

lost.– May access large number of data items - concurrency limited if

data inaccessible for long periods.– Deadlock more likely.– Cooperation through use of shared data items restricted by

traditional concurrency protocols.

Bina Nusantara

Advanced Transaction Models

• Look at five advanced transaction models:

– Nested Transaction Model– Sagas– Multi-level Transaction Model– Dynamic Restructuring– Workflow Models

Bina Nusantara

Transaction SupportTransaction

Action, or series of actions, carried out by user or application, which

accesses or changes contents of database.

• Logical unit of work on the database. • Application program is series of transactions with non-database

processing in between. • Transforms database from one consistent state to another, although

consistency may be violated during transaction.

Bina Nusantara

Transaction Support

Example Transaction

Bina Nusantara

Transaction Support

• Can have one of two outcomes:– Success - transaction commits and database reaches a new

consistent state. – Failure - transaction aborts, and database must be restored to

consistent state before it started. – Such a transaction is rolled back or undone.

• Committed transaction cannot be aborted.• Aborted transaction that is rolled back can be

restarted later.

Bina Nusantara

Transaction Support

State Transition Diagram for Transaction

Bina Nusantara

Transaction Support

Four basic (ACID) properties of a transaction are:• Atomicity ‘All or nothing’ property. • Consistency Must transform database from one

consistent state to another.• Isolation Partial effects of incomplete transactions

should not be visible to other transactions.• Durability Effects of a committed transaction are

permanent and must not be lost because of later failure.