Một view là không gì khác ngoài môt lệnh SQL mà được lưu giữ trong Database với một tên liên kết. Một view thực sự là một thành phần của một bảng trong form của một truy vấn SQL đã được định nghĩa trước.
Một view trong SQL có thể chứa tất cả các hàng của một bảng hoặc các hàng đã được chọn từ một bảng. Một view có thể được tạo từ một hoặc nhiều bảng, phụ thuộc vào truy vấn SQL đã viết để tạo một view.
View, về bản chất giống các Virtual Table (bảng ảo), cho phép người dùng thực hiện:
View được tạo bởi sử dụng lệnh CREATE VIEW. Các view có thể được tạo từ một bảng đơn, nhiều bảng hoặc từ view khác.
Để tạo một view, người dùng phải được trao quyền hệ thống thích hợp theo trình triển khai cụ thể.
CREATE VIEW ten_view AS
SELECT cot1, cot2.....
FROM ten_bang
WHERE [dieu_kien];
Bạn có thể bao nhiều bảng trong lệnh SELECT theo cách tương tự như bạn sử dụng chúng trong truy vấn SELECT thông thường.
Bảng SINHVIEN có các bản ghi sau:
+----+---------+-----+-----------+--------+
| ID | TEN | TUOI| KHOAHOC | HOCPHI |
+----+---------+-----+-----------+---------+
| 1 | Hoang | 21 | CNTT | 4000000 |
| 2 | Viet | 19 | DTVT | 3000000 |
| 3 | Thanh | 18 | KTDN | 4000000 |
| 4 | Nhan | 19 | CK | 4500000 |
| 5 | Huong | 20 | TCNH | 5000000 |
+----+---------+-----+-----------+---------+
Bây giờ là một ví dụ để tạo một view từ bảng này. View này sẽ được sử dụng để có TEN và TUOI của sinh viên:
SQL > CREATE VIEW SINHVIEN_VIEW AS
SELECT TEN, TUOI
FROM SINHVIEN;
Bây giờ, bạn có thể truy vấn SINHVIEN_VIEW theo cách tương tự bạn truy vấn một bảng thực sự. Sau đây là ví dụ:
SQL > SELECT * FROM SINHVIEN_VIEW;
Ví dụ trên sẽ cho kết quả:
+----------+-----+
| TEN | TUOI |
+----------+-----+
| Hoang | 21 |
| Viet | 19 |
| Thanh | 18 |
| Nhan | 19 |
| Huong | 20 |
+----------+-----+
WITH CHECK OPTION là một tùy chọn của lệnh CREATE VIEW. Mục đích của WITH CHECK OPTION là để bảo đảm rằng tất cả UPDATE và INSERT thỏa mãn các điều kiện trong định nghĩa view.
Nếu chúng không thỏa mãn các điều kiện, thì UPDATE và INSERT trả về một lỗi.
Ví dụ sau tạo cùng một view là SINHVIEN_VIEW với WITH CHECK OPTION.
CREATE VIEW SINHVIEN_VIEW AS
SELECT TEN, TUOI
FROM SINHVIEN
WHERE TUOI IS NOT NULL
WITH CHECK OPTION;
Trong trường hợp này, WITH CHECK OPTION nên từ chối bất kỳ giá trị NULL nào trong cột TUOI của view, bởi vì view được định nghĩa bởi dữ liệu mà không có giá trị NULL trong cột TUOI.
Một view có thể được cập nhật dưới các điều kiện cụ thể sau:
Vì thế, nếu một view thỏa mãn tất cả các qui tắc trên, thì bạn có thể cập nhật một view. Sau đây là ví dụ cập nhật TUOI của Hoang.
SQL > UPDATE SINHVIEN_VIEW
SET TUOI = 20
WHERE TEN='Hoang';
Cuối cùng, bảng SINHVIEN ban đầu được cập nhật và theo đó view được cập nhật. Bây giờ, thử truy vấn bảng ban đầu, và lệnh SELECT sẽ cho kết quả:
+----+---------+-----+-----------+--------+
| ID | TEN | TUOI| KHOAHOC | HOCPHI |
+----+---------+-----+-----------+---------+
| 1 | Hoang | 20 | CNTT | 4000000 |
| 2 | Viet | 19 | DTVT | 3000000 |
| 3 | Thanh | 18 | KTDN | 4000000 |
| 4 | Nhan | 19 | CK | 4500000 |
| 5 | Huong | 20 | TCNH | 5000000 |
+----+---------+-----+-----------+---------+
Các hàng dữ liệu có thể được chèn vào trong một view. Các qui tắc áp dụng cho lệnh UPDATE cũng sẽ được áp dụng cho lệnh INSERT trong SQL.
Ở đây, chúng ta không thể chèn các hàng vào trong SINHVIEN_VIEW bởi vì chúng ta không được bao gồm tất cả cột NOT NULL trong view này. Chúng ta có thể chèn các hàng vào trong một view theo cách tương tự khi bạn chèn chúng vào trong một bảng.
Các hàng dữ liệu có thể bị xóa từ một view. Các qui tắc áp dụng cho lệnh UPDATE và lệnh INSERT cũng sẽ được áp dụng cho lệnh DELETE trong SQL.
Ví dụ sau sẽ xóa một hàng có TUOI = 18.
SQL > DELETE FROM SINHVIEN_VIEW
WHERE TUOI = 18;
Cuối cùng, một hàng trong bảng SINHVIEN ban đầu sẽ bị xóa và kết quả tương tự với chính view đó. Bây giờ, thử truy vấn bảng ban đầu, và lệnh SELECT sẽ cho kết quả:
+----+---------+-----+-----------+--------+
| ID | TEN | TUOI| KHOAHOC | HOCPHI |
+----+---------+-----+-----------+---------+
| 1 | Hoang | 21 | CNTT | 4000000 |
| 2 | Viet | 19 | DTVT | 3000000 |
| 4 | Nhan | 19 | CK | 4500000 |
| 5 | Huong | 20 | TCNH | 5000000 |
+----+---------+-----+-----------+---------+
Rõ ràng là, khi bạn đã có một view, và việc không cần thiết sử dụng view này nữa thì điều cần làm là xóa chúng đi. Cú pháp cơ bản để xóa view trong SQL như sau:
DROP VIEW ten_view;
Ví dụ sau để xóa SINHVIEN_VIEW từ bảng ban đầu.
DROP VIEW SINHVIEN_VIEW;
Unpublished comment
Viết câu trả lời