intTypePromotion=1
zunia.vn Tuyển sinh 2024 dành cho Gen-Z zunia.vn zunia.vn
ADSENSE

Bài giảng Hệ quản trị cơ sở dữ liệu: Lập trình trên SQL Server - TS. Lại Hiền Phương (Phần 4)

Chia sẻ: Minh Vũ | Ngày: | Loại File: PDF | Số trang:45

43
lượt xem
5
download
 
  Download Vui lòng tải xuống để xem tài liệu đầy đủ

Phần 4 bài giảng "Hệ quản trị cơ sở dữ liệu: Lập trình trên SQL Server" cung cấp cho người học các kiến thức: Thủ tục lưu trữ, phân loại thủ tục lưu trữ, tạo thủ tục lưu trữ, tạo thủ tục lưu trữ bằng T-SQL,... Mời các bạn cùng tham khảo.

Chủ đề:
Lưu

Nội dung Text: Bài giảng Hệ quản trị cơ sở dữ liệu: Lập trình trên SQL Server - TS. Lại Hiền Phương (Phần 4)

  1. Lập trình trên SQL Server L Ạ I HI Ề N P HƯƠ NG BỘ M ÔN HT T T – K H OA CN T T E M A I L: L HP HUON G@TLU.EDU.VN LẠI HIỀN PHƯƠNG - HỆ QUẢN TRỊ CSDL 1
  2. Thủ tục lưu trữ (Stored Procedures) LẠI HIỀN PHƯƠNG - HỆ QUẢN TRỊ CSDL 2
  3. Khái niệm Thủ tục lưu trữ (Stored Procedure) là một đối tượng trong CSDL bao gồm một tập nhiều câu lệnh SQL được nhóm lại với nhau thành một nhóm. LẠI HIỀN PHƯƠNG - HỆ QUẢN TRỊ CSDL 3
  4. Đặc điểm Có thể nhận tham số truyền vào Có thể gọi thủ tục khác Trả về các giá trị thông qua các tham số Chuyển giá trị tham số cho các thủ tục được gọi Trả về giá trị trạng thái thủ tục là thành công hay không thành công LẠI HIỀN PHƯƠNG - HỆ QUẢN TRỊ CSDL 4
  5. Ưu điểm Lập trình theo module: thủ tục được xây dựng một lần trong CSDL, có thể được gọi nhiều lần bởi một hay nhiều ứng dụng. Thực hiện nhanh hơn: thực hiện một thủ tục lưu trữ nhanh hơn thực hiện một lượng lớn các câu lệnh T-SQL vì khi máy chủ nhận được mỗi câu lệnh đều phải kiểm tra tính hợp lệ quyền của tài khoản từ máy khách. LẠI HIỀN PHƯƠNG - HỆ QUẢN TRỊ CSDL 5
  6. Ưu điểm (tiếp) Làm giảm lưu lượng trên mạng: do chỉ cần gửi một câu lệnh gọi thủ tục thay vì phải gửi một tập các dòng lệnh từ ứng dụng đến máy chủ. An ninh bảo mật hơn: thay vì cấp phát quyền trực tiếp cho người sử dụng trên các câu lệnh SQL và trên các đối tượng CSDL, ta có thể cấp quyền cho người sử dụng thông qua thủ tục lưu trữ. Việc gán quyền như trên giúp cho vấn đề an ninh bảo mật trong CSDL tốt hơn. LẠI HIỀN PHƯƠNG - HỆ QUẢN TRỊ CSDL 6
  7. Phân loại thủ tục lưu trữ System stored procedure: Thủ tục được lưu trữ trong CSDL Master Bắt đầu bằng chữ sp_ Thường được sử dụng trong quản trị CSDL và an ninh bảo mật. Ví dụ: Muốn biết tất cả các tiến trình đang được thực hiện bởi user ‘sa’ sp_who @loginame = ‘sa’ LẠI HIỀN PHƯƠNG - HỆ QUẢN TRỊ CSDL 7
  8. Phân loại thủ tục lưu trữ (tiếp) Extended stored procedure: Thủ tục sử dụng chương trình ngoại vi đã được biên dịch thành DLL Bắt đầu bằng chữ xp_ Ví dụ:  Xp_sendmail dùng gửi mail  Xp_cmdshell dùng thực hiện lệnh của DOS  xp_cmdshell ‘dir c:\’ LẠI HIỀN PHƯƠNG - HỆ QUẢN TRỊ CSDL 8
  9. Phân loại thủ tục lưu trữ (tiếp) Local stored procedure: Nằm trong CSDL do người dùng tạo ra, thực hiện một công việc nào đó. Có thể được tạo ra trong CSDL master Temporary stored procedure: Tương tự như local store procedure nhưng được tạo ra trên CSDL TempDB Thủ tục tự hủy khi kết nối tạo ra nó ngắt hoặc SQL Server ngưng hoạt động Remote stored procedure: Thủ tục sử dụng thủ tục của một server khác LẠI HIỀN PHƯƠNG - HỆ QUẢN TRỊ CSDL 9
  10. Tạo thủ tục lưu trữ Bằng SQL Server Management Studio: Chọn CSDL cần tạo thủ tục Chọn Stored Procedures, kích chuột phải chọn New Stored Procedure Đặt tên thủ tục, xác định role người khai thác và soạn kịch bản câu lệnh LẠI HIỀN PHƯƠNG - HỆ QUẢN TRỊ CSDL 10
  11. Tạo thủ tục lưu trữ (tiếp) LẠI HIỀN PHƯƠNG - HỆ QUẢN TRỊ CSDL 11
  12. Tạo thủ tục lưu trữ bằng T-SQL Cú pháp CREATE PROCEDURE Tên_thủ_tục [(danh_sách_tham_số)] [WITH các_tùy_chọn] AS BEGIN Các_câu_lệnh_của_thủ_tục END Chú ý: Có thể viết tắt là CREATE PROC Cặp từ khóa BEGIN … END không bắt buộc LẠI HIỀN PHƯƠNG - HỆ QUẢN TRỊ CSDL 12
  13. Tạo thủ tục lưu trữ bằng T-SQL (tiếp) Tên thủ tục: tuân theo quy tắc định danh và không vượt quá 128 ký tự Danh sách tham số: các tham số được khai báo ngay sau tên thủ tục, cách nhau bởi dấu phảy. Khai báo mỗi tham số: @tên_tham_số kiểu_dữ_liệu VD: @maMH nvarchar(10) Tùy chọn: các tùy chọn cách nhau bởi dấu phảy, có các loại:  RECOMPILE: thông thường, thủ tục sẽ được dịch sẵn ở lần gọi đầu tiên. Nếu có tùy chọn RECOMPILE, thủ tục sẽ được dịch lại mỗi khi gọi  ENCRIPTION: yêu cầu mã hóa thủ tục. Nếu thủ tục đã được mã hóa, ta không thể xem được nội dung của thủ tục LẠI HIỀN PHƯƠNG - HỆ QUẢN TRỊ CSDL 13
  14. Tạo thủ tục lưu trữ bằng T-SQL (tiếp) Ví dụ: Từ CSDL QLSV với các bảng MonHoc(MaMon,TenMon,MoTa), SinhVien(MaSV, HoTen, GioiTinh, DiaChi, Email), KETQUA(MaSV, MaMon, Diem), viết thủ tục hiển thị MaSV, HoTen, TenMon, Diem của tất cả sinh viên. LẠI HIỀN PHƯƠNG - HỆ QUẢN TRỊ CSDL 14
  15. Xem một số thông tin về thủ tục Xem nội dung thủ tục sp_helptext tên_thủ_tục  Nội dung thủ tục không được hiển thị trong trường hợp thủ tục được tạo với tùy chọn ENCRYPTION Xem thông tin về người tạo, ngày giờ tạo sp_help tên_thủ_tục Xem các đối tượng mà các lệnh trong thủ tục tham chiếu đến: sp_depends tên_thủ_tục Liệt kê tất cả các thủ tục trong CSDL: sp_stored_procedures LẠI HIỀN PHƯƠNG - HỆ QUẢN TRỊ CSDL 15
  16. Thực thi (gọi) thủ tục lưu trữ Yêu cầu HQT CSDL thực thi thủ tục bằng lời gọi có dạng: tên_thủ_tục [ danh_sách_các_đối_số ]  Số lượng và thứ tự các đối số phải tương ứng với số lượng và thứ tự của các tham số khi định nghĩa thủ tục  Thứ tự của các đối số có thể không cần tuân theo thứ tự của tham số như khi định nghĩa thủ tục nếu đối số được viết dưới dạng: @tên_tham_số = giá_trị Gọi thủ tục bên trong một thủ tục khác, bên trong một trigger hay kết hợp với các câu lệnh SQL khác EXECUTE tên_thủ_tục [ danh_sách_các_đối_số ] Nếu gọi thủ tục trong CSDL khác, tên_thủ_tục phải viết đầy đủ: tên_CSDL.tên_người_tạo.tên_thủ_tục LẠI HIỀN PHƯƠNG - HỆ QUẢN TRỊ CSDL 16
  17. Sửa/Xóa thủ tục lưu trữ Khi một thủ tục được tạo ra, ta có thể tiến hành định nghĩa lại thủ tục bằng câu lệnh ALTER PROCEDURE, cú pháp như sau: ALTER PROCEDURE Tên_thủ_tục [(danh_sách_tham_số)] [WITH các_tùy_chọn] AS BEGIN Các_câu_lệnh_của_thủ_tục END Xóa một thủ tục đã có bằng DROP PROCEDURE: DROP PROCEDURE Tên_thủ_tục LẠI HIỀN PHƯƠNG - HỆ QUẢN TRỊ CSDL 17
  18. Sử dụng biến trong thủ tục Bên trong thủ tục có thể sử dụng các biến để lưu trữ các giá trị tính toán được hoặc truy xuất được từ CSDL Khai báo biến bằng từ khóa DECLARE như thông thường DECLARE @Tên_biến kiểu_dữ_liệu Biến được khai báo bên trong thủ tục chỉ được sử dụng bên trong thủ tục LẠI HIỀN PHƯƠNG - HỆ QUẢN TRỊ CSDL 18
  19. Sử dụng biến trong thủ tục (tiếp) Ví dụ: Viết thủ tục không có tham số hiển thị MaSV, HoTen, Diem của những sinh viên có điểm cao nhất môn Hệ Quản trị CSDL LẠI HIỀN PHƯƠNG - HỆ QUẢN TRỊ CSDL 19
  20. Thủ tục có tham số vào Tham số vào dùng để truyền giá trị vào trong thủ tục Cú pháp CREATE PROCEDURE Tên_thủ_tục @tên_tham_số_1 kiểu_dữ_liệu [, @tên_tham_số_2 kiểu_dữ_liệu, … ] [WITH các_tùy_chọn] AS BEGIN Các_câu_lệnh_của_thủ_tục END Gọi thủ tục [EXECUTE|EXEC] @tên_thủ_tục giá_trị_tham_số_1[,giá_trị_tham_số_2,…] [EXECUTE|EXEC] @tên_thủ_tục tham_số_1 = giá_trị_1 [, tham_số_2 = giá _trị_2,…] LẠI HIỀN PHƯƠNG - HỆ QUẢN TRỊ CSDL 20
ADSENSE

CÓ THỂ BẠN MUỐN DOWNLOAD

 

Đồng bộ tài khoản
3=>0