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

WHILE (T-SQL)

Chia sẻ: Lê Trinh | Ngày: | Loại File: PDF | Số trang:5

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

Thiết lập 1 điều kiện cho sự lặp lại của việc thi hành 1 câu lệnh SQL hay một khối lệnh. Các câu lệnh được chạy trong vòng lặp nhiều lần, miễn là điều kiện đã cho luôn thỏa. Việc thực hiện các câu lệnh trong vòng lặp WHILE, có thể được điều khiển từ bên trong vòng lặp với từ khóa BREAK và CONTINUE. Cú pháp : WHILE Biểu_thức_Boolean { câu_lệnh_SQL | khổi_lệnh | BREAK | CONTINUE } Các tham số : Biểu_thức_Boolean : là biểu thức trả về giá trị TRUE hay FALSE. Nếu biểu thức có chứa...

Chủ đề:
Lưu

Nội dung Text: WHILE (T-SQL)

  1. WHILE (T-SQL)
  2. Thiết lập 1 điều kiện cho sự lặp lại của việc thi hành 1 câu lệnh SQL hay một khối lệnh. Các câu lệnh được chạy trong vòng lặp nhiều lần, miễn là điều kiện đã cho luôn thỏa. Việc thực hiện các câu lệnh trong vòng lặp WHILE, có thể được điều khiển từ bên trong vòng lặp với từ khóa BREAK và CONTINUE. Cú pháp : WHILE Biểu_thức_Boolean { câu_lệnh_SQL | khổi_lệnh | BREAK | CONTINUE } Các tham số : - Biểu_thức_Boolean : là biểu thức trả về giá trị TRUE hay FALSE. Nếu biểu thức có chứa một lệnh SELECT thì câu lệnh SELECT phải được đóng ngoặc. Ví dụ : WHILE (SELECT COUNT(Manv) FROM NhanVien) < 50 … - câu_lệnh_SQL | khối_lệnh : Là bất kỳ câu lệnh T-SQL đơn nào, hay các câu lệnh được nhóm lại thành một khối lệnh. Để định nghĩa 1 khối lệnh, ta sử dụng các từ khóa điều khiển BEGIN và END. Ví dụ : WHILE … BEGIN UPDATE NhanVien SET Luong = Luong * 1.05 SELECT Manv,Luong FROM NhanVien END - Từ khóa BREAK : thoát khỏi vòng lặp WHILE trong cùng nhất. Các câu lệnh nằm sau từ khóa END kết thúc của vòng lặp sẽ thực thi bình thường.
  3. - Từ khóa CONTINUE : Làm cho vòng lặp WHILE bắt đầu một vòng lặp mới, vòng lặp cũ bị kết thúc nên các câu lệnh sau từ khóa CONTINUE sẽ bị bỏ qua.  Sử dụng vòng lặp WHILE với BREAK và CONTINUE : Nếu tổng giá của các sản phẩm nhỏ hơn 1000, ta tăng giá mỗi sản phẩm thêm 5%. Nếu sau khi tăng giá, tổng giá ít hơn hay bằng 1250 thì ta lặp lại việc tăng giá. Việc tăng giá kết thúc khi ta có tổng giá cao hơn 1250. WHILE (SELECT SUM(GiaSanPham) FROM SanPham) < 1000 BEGIN UPDATE SanPham SET GiaSanPham = GiaSanPham * 1.05 IF (SELECT SUM(GiaSanPham) FROM SanPham) > 1250 BREAK ELSE CONTINUE END CASE (T-SQL) Đánh giá theo một danh sách các điều kiện và trả về một trong nhiều biểu thức kết quả đã cho. CASE có thể được sử dụng ở bất kì câu lệnh hay mệnh đề chứa biểu thức nào. Cụ thể, ta có thể sử dụng CASE trong các câu lệnh SELECT, UPDATE, DELETE và SET. Còn các mệnh đề hỗ trợ CASE như IN, WHERE, ORDER BY và HAVING. Biểu thức CASE có 2 dạng : dạng cơ bản và dạng tìm kiếm. + Dạng cơ bản : so sánh 1 biểu thức với một tập các biểu thức đơn giản để chọn ra kết quả. + Dạng tìm kiếm : đánh giá một tập các biểu thức Boolean để chọn ra kết quả. Cú pháp : + Dạng cơ bản : CASE biểu_thức_so_sánh WHEN biểu_thức_điều_kiện_1 THEN biểu_thức_kết_quả_1 WHEN biểu_thức_điều_kiện_2 THEN biểu_thức_kết_quả_2 WHEN biểu_thức_điều_kiện_3 THEN biểu_thức_kết_quả_3 [ ...n ] [ ELSE biểu_thức_kết_quả_else ] END + Dạng tìm kiếm CASE WHEN biểu_thức_Boolean_điều_kiện_1 THEN biểu_thức_kết_quả_1 WHEN biểu_thức_Boolean _điều_kiện_2 THEN biểu_thức_kết_quả_2 WHEN biểu_thức_Boolean _điều_kiện_3 THEN biểu_thức_kết_quả_3 [ ...n ]
  4. [ ELSE biểu_thức_kết_quả_else ] END >>Tham số: - Biểu_thức_so_sánh : biểu thức cần đánh giá với các điều kiện ở CASE dạng cơ bản. - Biểu_thức_điều_kiện_x ( x=1,2,3… ) : là các biểu thức đơn giản để so sánh với biểu_thức_so_sánh ở CASE dạng cơ bản. Lưu ý, kiểu dữ liệu của biểu_thức_so_sánh và các biểu_thức_điều_kiện_x phải giống nhau hoặc phải có ép kiểu ngầm định. - Biểu_thức_Boolean_điều_kiện_x ( x=1,2,3… ) : là các biểu thức đơn giản để đánh giá TRUE/FALSE ở CASE dạng tìm kiếm. - Biểu_thức_kết_quả_x ( x=1,2,3… ) : là các biểu thức được trả về khi biểu_thức_so_sánh bằng với 1 trong các biểu_thức_điều_kiện, hoặc 1 trong biểu_thức_Boolean_điều_kiện có giá trị là TRUE. - Biểu_thức_kết_quả_else : là biểu thức trả về khi các so sánh đánh giá biểu thức không trả về TRUE. Nếu tham số này không có và không có so sánh nào trả về TRUE thì CASE trả về NULL. Lưu ý, kiểu dữ liệu của biểu_thức_điều_kiện và các biểu_thức_Boolean_điều_kiện phải giống nhau hoặc phải có ép kiểu ngầm định.  Sử dụng câu lệnh SELECT với CASE dạng cơ bản SELECT MaSanPham, TenSanPham, PhanLoai = CASE LoaiSanPham WHEN 'QA' THEN 'Quan Ao' WHEN 'GD' THEN 'Giay Dep' WHEN 'N' THEN 'Non' WHEN 'PK' THEN 'Phu Kien' ELSE 'Khac' END FROM SANPHAM  Sử dụng câu lệnh SELECT với CASE dạng tìm kiếm SELECT MaSinhVien, TenSinhVien, 'Ket Qua' = CASE WHEN TBDiemTichLuy < 5 THEN 'Khong Dat' WHEN TBDiemTichLuy >= 5 and TBDiemTichLuy < 6.5 THEN 'Trung Binh' WHEN TBDiemTichLuy >= 6.5 and TBDiemTichLuy < 8 THEN 'Kha' WHEN TBDiemTichLuy >= 8 and TBDiemTichLuy < 9 THEN 'Gioi' ELSE 'Xuat Sac' END FROM SinhVien IF… ELSE… Cú pháp :
  5. IF biểu_thức_điều_kiện { câu_lệnh_sql | khối_lệnh_sql } [ ELSE { câu_lệnh_sql | khối_lệnh_sql } ] Thiết lập điều kiện cho việc thực thi các câu lệnh T-SQL. Câu lệnh T-SQL sau từ khóa IF và biểu thức chứa điều kiện cần thỏa. Nếu biểu thức điều kiện được thỏa, câu lệnh T-SQL này sẽ được thực thi. Ngoài ra, nếu có từ khóa ELSE (tùy ý) thì câu lệnh sau ELSE sẽ được thực thi, khi biểu thức điều kiện không thỏa. Nếu biểu thức điều kiện có chứa câu lệnh SELECT thì câu SELECT phải được đóng ngoặc. Khối lệnh SQL được định nghĩa bởi BEGIN và END. Nếu không có khối lệnh thì chỉ 1 câu lệnh sau IF hoặc ELSE được thực hiện. Câu lệnh IF có thể được sử dụng lồng nhau. Ví dụ : IF (SELECT COUNT(MaSanPham) FROM SanPham) > 0 SELECT COUNT(MaSanPham) FROM SanPham ELSE PRINT 'Khong co san pham nao!' IF … EXISTS …
ADSENSE

CÓ THỂ BẠN MUỐN DOWNLOAD

 

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