! "# !"#!$ %&%' ()*!)!+!,-'.#/ ! .#0123"!$ %/4!5"()*! )!+6.&7).89:; '<=> !84 ?!.@A* B 6C' D!,-846 $ "# %E%F !"#$ % &' () *+,! / % 0! & ()123!&!"4 &1!"4"5)6 758-9' :;/ <=>?+@+- -+@+A";/ &' % &'( .;!& G.@H%!67I! !!'!JK/4!5"()*!)!+*L !6I %E%7*M'!JK/4! 5"!)!''F B:C5)$ D& B:CED&5) +,!4 BFG-"A$ED& & B:C /E5)+,!4758 -9HA;"5)+,!4"!" D& ) * N))OPPP?!&Q'!R!F <!+!I=>?++J* G S2 T2U2!' %!3!)%))3!) '6.&!R !!)).&.#JV'* WN.&.4 !X*)! K/!!11L!KMN +++J 'SYZ#!UG[3UG[ G[WJ6 ' 6.&!R!!))\?*=<*)!] SYZ3!^N))UG[%)3UG[ )36 G[WJ66W*/*J6(G+_6@6=.4)) .@!SYZ)) :/++J.&!R!> J> JVN))UG[ )3 G[WJ6G ' *)!.&!R!J`'* (+!I!"'J> /4!5"J> B*)!\? *=<%D*)!]SYZ!^N))UG[ )3G[WJ6G6SGUG_!R!!!'! 'J> /4!5"..&*!*)! + a^!WNSYZ)).# .&!R!!))3H.&] **)) \> !JI!*&*B))*H/>? !&!I!"'* WNb/>?!&' * WN!#J> /4!5"a^$ 6H />!@.&/<!R!!! 6J!<#8* c>*d*> '*6e4 !J`* WN!^.@f .9 !> !DSYZ , &* '*6/'#/"f%'! gJ4.h!J> /4!5"!!6 J> B*&!)%J c"f%'! '!6.hJ9 "VJV<>*$ %!! !!FD!%'! !6.hI!bD! !6I!/6 !(**+J> /4!5" G6F%'! !I!"'!6.h !!;#!6I! Q ijW*6 k c)6)!W)F<!g!! 6 / 01 'L=.&!RL/ F B:+O5)P!D% 0!HO5)/Q' B:+O5)17 ' B:5)"OO5)RL $ +' BS./EE0!+HA +,!4&O' B:+O5)H/-9.!' B:+5)HTDU+! H/' 2 3456 G S2cursor_name T2U2 lU SmnU[So liU20S2GpUeqm 2Uo lSZ mcqmGqeS\Z miSpiU20S2Go l2SGpUeqm 2UpU cmUYZ\ZZ o lqYp0S2eZeno iU2select_statement liU2TYGSlUicolumn_namel@n ooo 7 [...]... @titles _cursor GO 28 Thủ tục và tham số OUTPUT là CURSOR Thực thi 1 batch khai báo biến cursor cục bôê, thực thi thủ tục để gán output dạng cursor vào biến cục bôê DECLARE @MyCursor CURSOR EXEC titles _cursor @titles _cursor = @MyCursor OUTPUT WHILE (@@FETCH_STATUS = 0) BEGIN FETCH NEXT FROM @MyCursor END CLOSE @MyCursor DEALLOCATE @MyCursor GO 29 Khóa cursor Lêênh SELECT trong 1 cursor sẽ có cùng... thực thi 18 Đóng và giải phóng Cursor khỏi bộ nhớ Phải đóng cursor lại trước khi giải phóng nó khỏi bộ nhớ Cú pháp lệnh đóng cursor CLOSE cursor_ name Khi lệnh CLOSE được thực thi, cấu trúc của cursor vẫn còn và có thể mở lại được Để giải phóng cursor khỏi bộ nhớ DEALLOCATE cursor_ name 19 Ví dụ 1: Tạo 1 cursor đơn giản USE pubs GO DECLARE authors _cursor CURSOR FOR SELECT... báo cursor LOCAL: phạm vi của cursor là cục bộ trong phạm vi 1 batch, thủ tục, hay trigger trong đó cursor được tạo ra GLOBAL: phạm vi của cursor là tòan cục được dùng trong suốt phiên kết nối Cursor sẽ bi xóa khi mất kết nối 11 Khai báo cursor Forward-only: chỉ có thể đọc (fetch) các hàng một cách tuần tự từ đầu đến cuối bộ kết quả Nếu sử dụng FORWARD_ONLY mà không dùng. .. KEYSET, hay DYNAMIC thì cursor sẽ được tạo như 1 DYNAMIC cursor Khi không dùng cả FORWARD_ONLY và SCROLL thì FORWARD_ONLY được xem như măêc đinh trừ phi có dùng các từ khóa STATIC, KEYSET, or DYNAMIC (măêc đinh của STATIC, KEYSET, và DYNAMIC là SCROLL) FORWARD_ONLY chỉ hỗ trợ cho các loại cursor STATIC, KEYSET, và DYNAMIC SCROLL: cho phép sử dụng tất cả các tuỳ chọn của lệnh đọc (FIRST,... GO Cursor và thủ tục thực thi cursor EXEC OpenCrsr; /* DECLARES and OPENS SampleCrsr */ GO EXEC ReadCrsr; /* Fetches the rows from SampleCrsr */ GO CLOSE SampleCrsr; GO DEALLOCATE SampleCrsr; GO 27 Thủ tục và tham số OUTPUT là CURSOR USE pubs PROCEDURE titles _cursor @titles _cursor CURSOR VARYING OUTPUT AS SET @titles _cursor = CURSOR FORWARD_ONLY STATIC FOR SELECT * FROM titles OPEN @titles _cursor. .. thứ tự của hàng đó 13 Khai báo cursor KEYSET: xác đinh thứ tự các hàng trong cursor là cố đinh khi cursor được mở Tâêp hợp các khóa xác đinh tính duy nhất các hàng được xây dựng trong 1 bảng của tempdb Các thay đổi vào giá tri không phải khoá ngay trong bảng gốc được thực hiện bởi người tạo cursor hay từ các người dùng khác đều có thể nhìn thấy được từ cursor khi... hàng của cursor DECLARE complex _cursor CURSOR scroll FOR SELECT cShopperId FROM dbo.Shopper WHERE cShopperId not in (SELECT cShopperId from dbo.Orders) OPEN complex _cursor; FETCH absolute 5 FROM complex _cursor; DELETE dbo.Shopper WHERE CURRENT OF complex _cursor; CLOSE complex _cursor; DEALLOCATE complex _cursor; 24 Ví dụ: lệnh Update dùng dữ liệu hàng hiện hành của cursor USE Pubs CREATE TABLE dbo.Table1... authors _cursor Perform the first fetch FETCH NEXT FROM authors _cursor 20 WHILE @@FETCH_STATUS = 0 BEGIN FETCH NEXT FROM authors _cursor END CLOSE authors _cursor DEALLOCATE authors _cursor GO Ví dụ 2: dùng scroll và tùy chọn của fetch USE pubs GO DECLARE authors _cursor SCROLL CURSOR FOR SELECT au_lname, au_fname FROM authors ORDER BY au_lname, au_fname OPEN authors _cursor Fetch the last row in the cursor. .. FROM authors _cursor CLOSE authors _cursor DEALLOCATE authors _cursor GO Cursor có thể cập nhật (Updatable cursor) Updatable cursors hỗ trợ các lêênh sửa đổi dữ liêêu cho phép câêp nhâêt các hàng thông qua cursor Sau khi đã đinh vi 1 hàng trong updatable cursor , có thể dùng lêênh update hay delete trên bản gốc đã dùng để tạo cursor Thao tác này được gọi là positioned updates Positioned... lệnh đọc (FIRST, LAST, PRIOR, NEXT, RELATIVE, ABSOLUTE) 12 Khai báo cursor Static: bộ kết quả được khôi phục và lưu trữ trong 1 bảng của CSDL tempdb Những sửa đổi được làm trong bảng gốc sẽ không được phản ánh trong dữ liệu đọc được từ cursor và cursor này không chấp nhận bất kỳ sửa đổi nào DYNAMIC: tạo 1 cursor phản ánh tất cả những thay đổi dữ liệu xảy ra tại các hàng . '6.&!R !!)).&.#JV'* WN.&.4 !X*)! K/! !11 L!KMN +++J 'SYZ#!UG[3UG[ G[WJ6. $ +' BS./EE0!+HA +,!4&O' B:+O5)H/-9.!' B:+5)HTDU+! H/' 2 3456 G S2 cursor_ name T2U2 lU SmnU[So liU20S2GpUeqm 2Uo lSZ mcqmGqeS miSpiU20S2Go l2SGpUeqm