Giáo trình Hệ quản trị cơ sở dữ liệu - Chương 8: Hàm (Function) - Lê Thị Minh Nguyên

CREATE FUNCTION f_DSKhachHang (@MaKH int) RETURNS @myKhachHang table (MaKH int, TenKH nvarchar(50), NgayDatHang datetime) AS Begin Else Insert into @myKhachHang Select kh.MaKH, kh.TenKH, dh.NgayDatHang From KhachHang kh, DonHang dh Where kh.MaKH=dh.MaKH and kh.MaKH = @MaKH Return End

pdf5 trang | Chia sẻ: huongthu9 | Lượt xem: 467 | Lượt tải: 0download
Bạn đang xem nội dung tài liệu Giáo trình Hệ quản trị cơ sở dữ liệu - Chương 8: Hàm (Function) - Lê Thị Minh Nguyên, để tải tài liệu về máy bạn click vào nút DOWNLOAD ở trên
8/25/2017 1 Chương 8. Hàm (Function) GV: Lê Thị Minh Nguyện Email: nguyenltm@huflit.edu.vn Nội dung 1. Khái niệm 2. Các loại Function 3. Hàm Scalar 4. Hàm Inline table valued 5. Hàm Multi statement table valued 6. Nhận xét Hệ quản trị Cơ sở dữ liệu 2 1. Khái niệm • Cũng giống như Stored Procedure Hàm là một đối tượng trong cơ sở dữ liệu 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. • Điểm khác biệt giữa hàm và thủ tục là hàm trả về một giá trị thông qua tên hàm. Điều này cho phép ta sử dụng hàm như là một thành phần của một biểu thức chẳng hạn như trong các câu lệnh truy vấn hay các câu lệnh thực hiện cập nhật dữ liệu Hệ quản trị Cơ sở dữ liệu 3 2. Các loại Function • Loại 1: Hàm được định nghĩa sẵn trong DBMS • Loại 2: Hàm do người dùng định nghĩa • Giá trị trả về là “dữ liệu kiểu bảng” • Giá trị trả về là một giá trị – Scalar-valued Hệ quản trị Cơ sở dữ liệu 4 8/25/2017 2 3. Hàm Scalar Hệ quản trị Cơ sở dữ liệu 5 Hàm vô hướng trả về duy nhất một giá trị dựa trên tham số truyền vào. Cú pháp CREATE FUNCTION func_name ([Danh_Sach_Cac_Tham_So]) RETURNS Kieu_Du_Lieu_Tra_Ve_Cua_Ham AS BEGIN các_câu_lenh_của_hàm END 3. Hàm Scalar (tt) Hệ quản trị Cơ sở dữ liệu 6 CREATE FUNCTION Test_function(@b int, @c int) RETURNS int AS BEGIN declare @kq int if @b>2 set @kq=@b+@c else set @kq=@b+@c+1 return @kq END Gọi hàm SELECT dbo. Test_function(3,4) 3. Hàm Scalar (tt) Hệ quản trị Cơ sở dữ liệu 7 CREATE FUNCTION GiaiThua(@x int) RETURNS int AS Begin Declare @i int If @x>20 OR @x IS NULL Set @i = NULL Else If @x < 2 Set @i = @x Else Set @i = @x * dbo.GiaiThua(@x-1) Return @i End SELECT dbo.GiaiThua(3) 3. Hàm Scalar(tt) Hệ quản trị Cơ sở dữ liệu 8 CREATE FUNCTION f_thu (@ngay datetime) returns nvarchar(10) As Begin declare @st nvarchar(10) select @st=case datepart(dw,@ngay) when 1 then N'chủ nhật' when 2 then N'thứ hai’ when 3 then N 'thứ ba’ when 4 then N 'thứ tư’ when 5 then N 'thứ năm’ when 6 then N 'thứ sáu’ else N 'thứ bảy’ End Return @st End 8/25/2017 3 3. Hàm Scalar (tt) Hệ quản trị Cơ sở dữ liệu 9 Thực thi hàm: Select MaNV, TenNV, dbo.f_thu (NgayVaoLam) From NhanVien Kết qủa: 4. Hàm Inline table valued Hàm nội tuyến, trả về dạng bảng. Cú pháp: CREATE FUNCTION func_name ([Danh_Sach_Cac_Tham_So]) RETURNS TABLE AS RETURN (câu_lenh_select) Hệ quản trị Cơ sở dữ liệu 10 • Kiểu trả về của hàm phải được chỉ định bởi mệnh đề RETURNS TABLE • Trong phần thân của hàm chỉ có duy nhất một câu lệnh RETURN 4. Hàm Inline table valued (tt) Hàm nội tuyến, trả về dạng bảng. Cú pháp: CREATE FUNCTION func_name ([Danh_Sach_Cac_Tham_So]) RETURNS TABLE AS RETURN (câu_lenh_select) Hệ quản trị Cơ sở dữ liệu 11 • Kiểu trả về của hàm phải được chỉ định bởi mệnh đề RETURNS TABLE • Trong phần thân của hàm chỉ có duy nhất một câu lệnh RETURN 4. Hàm Inline table valued (tt) Hệ quản trị Cơ sở dữ liệu 12 Tạo hàm trả về các khách hàng tùy thuộc vào giá trị mã khách hàng truyền vào cho tham số CREATE FUNCTION f_KhachHang (@MaKH int) RETURNS TABLE AS RETURN (Select * From KhachHang Where MaKH > @MaKH) 8/25/2017 4 4. Hàm Inline table valued (tt) Hệ quản trị Cơ sở dữ liệu 13 Thực thi hàm: SELECT tmp.TenKH, dh.NgayDatHang FROM DonHang dh, dbo.f_KhachHang(3) as tmp WHERE dh.MaKH = tmp.MaKH 5. Hàm Multi statement table valued 14 Hàm gồm nhiều câu lệnh SQL bên trong, trả vê dạng bảng. Cú pháp: CREATE FUNCTION func_name ([Danh_Sach_Cac_Tham_So]) RETURNS @biến_bảng TABLE định_nghia_bảng AS BEGIN các_câu_lenh_trong_thân_hàm RETURN END Lưu ý: sau từ khóa RETURNS là một biến bảng được định nghĩa và sau từ khóa RETURN cuối hàm không có tham sô nào đi kèm 15 CREATE FUNCTION f_DSKhachHang (@MaKH int) RETURNS @myKhachHang table (MaKH int, TenKH nvarchar(50), NgayDatHang datetime) AS Begin If @MaKH = 0 Insert into @myKhachHang Select kh.MaKH, kh.TenKH, dh.NgayDatHang From KhachHang kh, DonHang dh Where dh.MaKH = kh.MaKH --- 5. Hàm Multi statement table valued (tt) 16 CREATE FUNCTION f_DSKhachHang (@MaKH int) RETURNS @myKhachHang table (MaKH int, TenKH nvarchar(50), NgayDatHang datetime) AS Begin --- Else Insert into @myKhachHang Select kh.MaKH, kh.TenKH, dh.NgayDatHang From KhachHang kh, DonHang dh Where kh.MaKH=dh.MaKH and kh.MaKH = @MaKH Return End 5. Hàm Multi statement table valued (tt) 8/25/2017 5 17 Thực thi hàm: Select * From f_DSKhachHang (0) 5. Hàm Multi statement table valued (tt) Hệ quản trị Cơ sở dữ liệu 18

Các file đính kèm theo tài liệu này:

  • pdfgiao_trinh_he_quan_tri_co_so_du_lieu_chuong_8_ham_function_l.pdf