Bài giảng Cơ sở dữ liệu - Chương 6: Giới thiệu về giao tác - Phạm Nguyên Thảo
Khi dead lock xảy ra
– SQL Server sẽ chọn 1 trong 2 transaction gây dead
lock để hủy bỏ, khi đó transaction còn lại sẽ được
tiếp tục thực hiện cho đến khi hoàn tất
– Transaction bị chọn hùy bỏ là transaction mà SQL
ước tính chi phí cho phần việc đã làm được ít hơn
transaction còn lại.
44 trang |
Chia sẻ: huongthu9 | Lượt xem: 622 | Lượt tải: 0
Bạn đang xem trước 20 trang tài liệu Bài giảng Cơ sở dữ liệu - Chương 6: Giới thiệu về giao tác - Phạm Nguyên Thảo, để xem tài liệu hoàn chỉnh bạn click vào nút DOWNLOAD ở trên
Trường Đại học Khoa học Tự nhiên
Khoa Công nghệ Thông tin
Bộ môn Hệ thống Thông tin
30-11-2006
Chương 6: Giới thiệu về giao tác
Chương VII : Transaction 2
Giao tác (transaction)
• Ví dụ : chuyển khoản 100$ từ tài khoản A sang tài
khoản B (50$). Các bước thực hiện gồm :
– Trừ 100$ khỏi tài khoản A
– Nếu số dư trong A >= 100$ thì
cộng 50$ vào tài khoản B
• Giả sử vừa trừ tiền khỏi tài khoản A thì sự cố kỹ
thuật xảy ra, và các bước tiếp theo không được
thực hiện
– A mất 100$ nhưng B không nhân được tiền (!?).
• Các bước xử lý nêu trên nếu đã làm thì phải làm
cho hết, ngược lại thì không làm bước nào cả
chúng tạo thành một transaction, nói cách khác là
một đơn vị công việc nguyên tố.
3
Khái niệm
• Giao tác (transaction) là một tập hợp có thứ tự các
thao tác. Tập hợp này được xem như một đơn vị công
việc.
– i.e. tất cả thao tác trong giao tác phải được thực hiện thành
công, hoặc không thao tác nào được thực hiện.
– nếu có một thao tác không hoàn thành được thì toàn bộ giao
tác cũng không hoàn thành.
• Giao tác chuyển CSDL từ tình trạng nhất quán này
sang tình trạng nhất quán khác. Ngoài ra còn có tính
chất ACID sẽ bàn đến dưới đây.
4
Khái niệm (tt)
• Một số thuật ngữ liên quan đến giao tác
– Begin [transaction/tran] : bắt đầu một transaction
– Commit [transaction/tran] : hoàn tất một transaction
– Rollback [transaction/tran] : quay lui, hủy bỏ toàn bộ
phần giao tác đã thực hiện trước đó
5
Tính chất của giao tác: ACID
• Tính nguyên tố (Atomic) : tất cả thao tác trong giao tác phải
được thực hiện thành công, hoặc không thao tác nào được thực
hiện.
• Tính nhất quán (Consistency) : Chuyển CSDL từ tình trạng
nhất quán này sang tình trạng nhất quán khác.
6
Tính chất của giao tác (tt)
• Tính độc lập (Isolation) : xử lý của một giao tác phải độc lập
với những tác động (thấy or thay đổi dữ liệu) của các giao tác
khác thực hiện đồng thời
• Tính bền vững (Durability) : Sau khi giao tác commit thành
công, tất cả những thay đổi trên CSDL mà giao tác đã thực hiện
phải được ghi nhận chắc chắn (vào ổ cứng).
– HQT CSDL luôn phải có cơ chế phục hồi dữ liệu để đảm bảo điều
này, thường dùng cơ chế ghi nhận bằng transaction log.
12
Ghi chú : Đảm bảo tính Automic
• Để đảm bảo tính chất A của giao tác
Người sử dụng phải tường minh điều khiển sự
rollback của giao tác.
• Cần kiểm tra lỗi sau khi thực hiện mỗi thao tác trong
giao tác để có thể xử lý rollback kịp thời.
– Trong SQL Server, dùng biến toàn cục @@error và
@@rowcount
13
Cài đặt thêm sinh viên
• Dùng Stored:
Create proc.
Begin
/*Goi lệnh insert thêm mới vào SinhVien*/
/* Đọc và kiểm tra SiSo lớp */
/* Nếu SiSo >= Max , báo lỗi */
rollback transaction
/*Cập nhật tăng sỉ số*/
/* Nếu có lỗi khi thực hiện thao tác :*/
rollback transaction
End
14
Ví dụ - kiểm lỗi bằng @@error
Create proc sp_ThemSV @MaSV int, @MaLop int
As
begin transaction
declare @SiSo int
select @SiSo = SiSo
from LOP
where MaLop = @MaLop
if(@SiSo>=Max)
begin
rollback transaction
return
end
15
Ví dụ (tt)
Insert into SINH_VIEN(MaSV,MaLop)
values(@MaSV,@MaLop)
if(@@error0)
begin
rollback transaction
return
end
16
Ví dụ (tt)
update LOP
set SiSo = SiSo+1
where MaLop = @MaLop
if(@@error0)
begin
rollback transaction
return
end
commit transaction /* hoàn tất giao tác*/
/*end stored proc*/
17
Các vấn đề liên quan đến xử lý truy xuất đồng thời
• Lost Update (mất dữ liệu cập nhật)
• Dirty read (đọc dữ liệu “rác”)
• Unrepeatable read (không thể đọc lặp lại)
• Phantom (“bóng ma”)
• Mất dữ liệu cập nhật (Lost update)
– Tình trạng này xảy ra khi có nhiều hơn một giao tác
cùng thực hiện cập nhật trên 1 đơn vị dữ liệu. Khi
đó, tác dụng của giao tác cập nhật thực hiện sau sẽ
đè lên tác dụng của thao tác cập nhật trước.
• Đọc dữ liệu chưa commit (Uncommitted data,
Dirty read)
– Xảy ra khi một giao tác thực hiện đọc trên một đơn
vị dữ liệu mà đơn vị dữ liệu này đang bị cập nhật
bởi một giao tác khác nhưng việc cập nhật chưa
được xác nhận đã hoàn tất.
18
• Thao tác đọc không thể lặp lại (Unrepeatable data)
– Tình trạng này xảy ra khi một giao tác T1 vừa thực hiện
xong thao tác đọc trên một đơn vị dữ liệu (nhưng chưa
commit) thì giao tác khác (T2) lại thay đổi (ghi) trên đơn
vị dữ liệu này. Điều này làm cho lần đọc sau đó của T1
không còn nhìn thấy dữ liệu ban đầu nữa.
• Bóng ma (Phantom)
– Là tình trạng mà một giao tác đang thao tác trên một tập
dữ liệu nhưng giao tác khác lại chèn thêm hoặc xóa đi
các dòng dữ liệu vào tập dữ liệu mà giao tác kia quan
tâm.
19
20
Cách giải quyết các vấn đề
• Dùng khái niệm giao tác
• và Dùng cơ chế khoá
– Write lock (exclusive lock)
– Read lock (shared lock)
– Các hệ quản trị cụ thể còn có những loại khoá mở
rộng khác : updlock, holdlock,
– Đặt khóa vào đơn vị dữ liệu
Tự động (đặt mức cô lập cho giao tác)
Thủ công (đặt cấp độ khóa trong câu SELECT)
Nội dung trình bày
• Giao tác (Transaction)
• Xử lý đồng thời (Concurrency)
• Chế độ khóa
• Khai báo tường minh giao tác
• Mức cô lập
• Các cấp độ khóa
• Dead-lock
21 Chương VII : Transaction
Chế độ khóa
• Các loại khóa
– Khóa chia sẻ (shared lock) : Còn gọi là khóa đọc
(read lock) . Gọi tắt : Khóa S
– Khóa dự định ghi (Intend to write lock) : Còn gọi là
khóa cập nhật (update lock) . Gọi tắt : Khóa U
– Khóa độc quyền (exclusive lock) : Còn gọi là khóa
ghi (write lock). Gọi tắt : Khóa X.
Khóa X luôn được phát ra khi ghi, bất kể thông số hệ
thống đang thiết lập thế nào.
Sở dĩ như vậy vì HQT hỗ trợ xử lý đồng thời các thao tác
đọc nhưng ghi phải ghi lần lượt.
22 Chương VII : Transaction
Chế độ khóa
• Bảng tương thích giữa các chế độ khóa
23 Chương VII : Transaction
gt T
vs gt T’
S U X
S
U
X
Tương thích: T’ không phải chờ T
Không tương thích: T’ phải chờ T giải phóng khóa
Chế độ khóa
• Khi một transaction Ti cần truy cập và thao tác
trên một đơn vị dữ liệu X, nó sẽ đòi phát khóa
A trên X.
• Nhưng khi ấy nếu transaction Tj đang giữ khóa
B trên X (và khóa A với khóa B không tương
thích) thì Ti phải đợi Tj giải phóng khóa B trên
X nó mới phát được khóa A trên X Hiện
tượng chờ đợi lẫn nhau.
24 Chương VII : Transaction
Nội dung trình bày
• Giao tác (Transaction)
• Xử lý đồng thời (Concurrency)
• Chế độ khóa
• Khai báo tường minh giao tác
• Mức cô lập
• Các cấp độ khóa
• Dead-lock
25 Chương VII : Transaction
Khai báo tường minh giao tác
• Trong SQL Server, ta có thể khai báo tường
minh các giao tác, có thể là trên một khối lệnh
độc lập hay trong thân một thủ tục thường trú.
• Ngoài ra SQL Server còn có thể phát sinh các
giao tác ngầm định (Ví dụ : Trigger)
26 Chương VII : Transaction
Khai báo tường minh giao tác
• Các chỉ thị :
– Begin tran : Đặt trước dòng lệnh đầu tiên của giao
tác (1 chỉ thị duy nhất cho 1 giao tác)
– Commit tran : Đặt sau dòng lệnh cuối cùng hoàn tất
giao tác (1 chỉ thị duy nhất cho 1 giao tác)
– Rollback tran : Đặt tại các vị trí kiểm lỗi hay các
nhánh rẽ logic ứng với trường hợp nghiệp vụ thất
bại. (nhiều chỉ thị cho 1 giao tác)
27 Chương VII : Transaction
?
Khai báo tường minh giao tác
• Kiểm lỗi trong giao tác
– Lỗi có thể sảy ra sau các thao tác :
Insert, Update (trùng khóa chính, sai kiểu dữ liệu, sai định dạng
ngày tháng,)
Delete (ràng buộc tồn tại,)
Select (login không có quyền trên object)
– Sau mỗi thao tác trên phải kiểm lỗi bằng biến hệ thống
@@error (=0 không có lỗi,≠0 có lỗi)
28 Chương VII : Transaction
Khai báo tường minh giao tác
• Kiểm lỗi trong giao tác
– Khi lỗi sảy ra (@@error ≠ 0), cần thực hiện các
công việc :
Báo lỗi (nếu cần) bằng các lệnh print hay raise error
Rollback tran (bắt buộc)
Nếu Tran khai báo trong SP thì thông thường gọi lệnh
return để kết thúc SP (tính automic)
29 Chương VII : Transaction
Khai báo tường minh giao tác
• Ví dụ đoạn lệnh kiểm lỗi trong giao tác
If @@error 0
Begin
Print ‘’
Rollback tran
Return
End
30 Chương VII : Transaction
Khối lệnh kiểm
tra lỗi
Nội dung trình bày
• Giao tác (Transaction)
• Xử lý đồng thời (Concurrency)
• Chế độ khóa
• Khai báo tường minh giao tác
• Mức cô lập
• Các cấp độ khóa
• Dead-lock
31 Chương VII :
Transaction
Mức cô lập cho giao tác
• Mục đích: tự động đặt khóa cho các thao tác
(đọc) trong kết nối dữ liệu hiện hành.
32
Mức cô lập cho giao tác
• Ghi chú
– Tầm vực của Isolation level là ở mức connection chứ
không phải mức transaction.
Khi 1 connection N được đặt mức cô lập X thì X sẽ phát huy
hiệu lực trên tất cả các transaction Ti chạy trên N.
– Mức cô lập chỉ quyết định cách phát và giữ khóa S
của transaction (vì khóa X luôn được phát ra khi ghi).
Mức cô lập không quan tâm khóa U
33 Chương VII :
Transaction
Mức cô lập cho giao tác
• Bốn mức cô lập mà SQL Server cung cấp
– Read Uncommited : Không phát S khi đọc. Có nhu
cầu đọc tức thời, e.g. khi cần đánh giá tổng quát
toàn hệ thống. Tuy nhiên, không giải quyết được
bất cứ vấn đề xử lý đống thời nào.
– Read Commited : Phát S khi đọc, giải phóng S
ngay sau khi đọc. Chỉ giải quyết được Dirty Read
34 Chương VII :
Transaction
Mức cô lập cho giao tác
• Bốn mức cô lập mà SQL Server cung cấp
– Repeatable Read : Phát S khi đọc và giữ S đến khi
transaction kết thúc. Không ngăn chặn lệnh
insert/delete dữ liệu thoả điều kiện thiết lập S. Giải
quyết được Dirty Read và Unrepeatable Read
– Seralizable : Giống Repeatable Read nhưng có
ngăn chặn lệnh insert/delete dữ liệu thoả điều kiện
thiết lập S. Giải quyết được Dirty Read và
Unrepeatable Read và Phantom
35 Chương VII :
Transaction
Mức cô lập cho giao tác
• Thiết lập :
– Đặt lệnh thiết lập cần thiết trước khi bắt đầu giao
tác.
– Thiết lập mặc định là Read Commited.
– Lệnh thiết lập :
Set transaction Isolation level Tên_MứcCôLập
– Ví dụ :
Set transaction Isolation level Read Commited
Set transaction Isolation level Serializable
36 Chương VII :
Transaction
Nội dung trình bày
• Giao tác (Transaction)
• Xử lý đồng thời (Concurrency)
• Chế độ khóa
• Khai báo tường minh giao tác
• Mức cô lập
• Các cấp độ khóa
• Dead-lock
37 Chương VII :
Transaction
Các cấp độ khóa
• Đặt vấn đề : Mức cô lập là chưa đủ
– Mức cô lập quyết định cách phát và giữ khóa S
trong một transaction và có hiệu lực trên tất cả các
thao tác đọc trong transaction đó.
– Thực tế, ta cần phát và giữ khóa S theo các cách
khác nhau cho các thao tác đọc khác nhau trong
cùng một transaction
– Ngoài ra, ta cũng cần dùng nhiều dạng khóa linh
động hơn là chỉ 1 loại khóa S đơn giản
38 Chương VII :
Transaction
Các cấp độ khóa
• Khái niệm
– Cấp độ khóa là các loại khóa khác nhau (không chỉ
khóa S) được gắn vào từng table trong mệnh đề
from của từng thao tác select
– Ngoài lệnh select, cấp độ khóa còn có thể gắn vào
các câu lệnh cập nhật, tuy nhiên ở đây ta chỉ quan
tâm câu select
39 Chương VII :
Transaction
Các cấp độ khóa
• Các cấp độ khóa
– Read Uncommited / No lock
– Read Commited (mặc định)
– Repeatable
– Serializable / Hold lock
– Updlock
– Tablock
– TablockX
– ReadPast
40 Chương VII :
Transaction
Các cấp độ khóa
• Cách thiết lập
Select
From {Tab1 Alias1 with Lock_mode [,n]} [,n]
Where
• Ví dụ :
Select SV.HoVaTen, K.TenKhoa
From SinhVien SV with ReadCommite,
Khoa K with Updlock
Where SV.Khoa = K.Ma And Year(SV.NgaySinh) >= 1983
41 Chương VII :
Transaction
Các cấp độ khóa
• Phối hợp với Isolation Level
– Trong transaction luôn có các thao tác yêu cầu bảo
vệ nghiêm ngặt và các thao tác ít yêu cầu bảo vệ
nghiêm ngặt
– Dùng Isolation level ứng với yêu cầu bảo vệ ít
nghiêm ngặt nhất
– Bổ sung lock mode vào các thao tác yêu cầu bảo
vệ nghiêm ngặt hơn mức mà Isolation level đó cung
cấp.
42 Chương VII :
Transaction
Các cấp độ khóa
• Khóa với dữ liệu trong cursor
– Nếu cursor là loại tĩnh (static) thì các đơn vị dữ liệu
đọc ra sẽ được lock ngay khi vừa Open cursor
– Nếu cursor là loại động (dynamic) thì fetch đến đâu
sẽ khóa đến đó
– Cách phát khóa và giữ khóa là do mức cô lập của
connection và các lock mode trong câu select định
nghĩa cursor quyết định
43 Chương VII :
Transaction
Nội dung trình bày
• Giao tác (Transaction)
• Xử lý đồng thời (Concurrency)
• Chế độ khóa
• Khai báo tường minh giao tác
• Mức cô lập
• Các cấp độ khóa
• Dead-lock
44 Chương VII :
Transaction
Dead lock
• Khái niệm
– Khi xử lý đồng thời, không tránh khỏi việc
transaction này phải chờ đợi transaction khác
– Nếu vì lý do gì đó mà hai transaction lại chờ lẫn
nhau vĩnh viễn, không cái nào trong hai có thể hoàn
thành được thì ta gọi đó là hiện tượng Dead Lock
45 Chương VII :
Transaction
Dead lock
• Phân loại
– Cyclic Deadlock
– Conversion Deadlock
46 Chương VII :
Transaction
Dead lock
• Phân loại
– Cyclic Deadlock
47 Chương VII :
Transaction
Đơn vị DL 1
Đơn vị DL 2
T1
Giữ khóa A
Trên đơn vị DL 1
Cần phát khóa B2
(không tương thích với B)
Trên đơn vị DL 2
Đơn vị DL 2
Đơn vị DL 1
T2
Giữ khóa B
Trên đơn vị DL 2
Cần phát khóa A2
(không tương thích với A)
Trên đơn vị DL 2
DEAD
LOCK
Dead lock
• Phân loại
– Conversion Deadlock
48 Chương VII :
Transaction
DEAD
LOCk
Đơn vị
dữ liệu
A
T1
Giữ S-Lock
Nâng cấp
thành X-Lock
T2
Giữ S-Lock
Nâng cấp
thành X-Lock
Dead lock
• Khi dead lock xảy ra
– SQL Server sẽ chọn 1 trong 2 transaction gây dead
lock để hủy bỏ, khi đó transaction còn lại sẽ được
tiếp tục thực hiện cho đến khi hoàn tất
– Transaction bị chọn hùy bỏ là transaction mà SQL
ước tính chi phí cho phần việc đã làm được ít hơn
transaction còn lại.
49 Chương VII :
Transaction
Các file đính kèm theo tài liệu này:
- bai_giang_co_so_du_lieu_chuong_6_gioi_thieu_ve_giao_tac_pham.pdf