Chương 10 VIEWS

Một phần của tài liệu Oracle PLSQL Language pot (Trang 74 - 76)

- Thay DEPTNO của các nhân viên này bằng DEPTNO của Boston Thay lương mỗi nhân viên bằng lương trung bình của bộ phậ n * 1.1 Thay commission c ủ a

Chương 10 VIEWS

10.1.VIEWS

10.1.1. Tạo view

View là một table logic, view không phải là nơi lưu trữ dữ liệu ở mức vật lý. Các thành phần của view dựa trên table hoặc là trên view khác. Mọi tác động lên view đều gây ảnh hưởng tới table của view đó, và ngược lại. Đểđịnh nghĩa một view dùng query trên một bảng hay một view nào đó.

Cú pháp:

CREATE [OR REPLACE] [FORCE] VIEW view_name [(column, column,...)] AS

SELECT statement

[WITH CHECK OPTION [CONSTRAINT constraint_name]];

Trong đó:

OR REPLACE Để tạo view chèn lên view cùng tên FORCE Để tạo view cả khi table hay view nào đó

không tồn tại trong câu lệnh SELECT. column, column Tên các column của view

WITH CHECK OPTION Nếu có lệnh insert hoặc update lên vieư, ql sẽ kiểm tra điều kiện phù hợp trong mệnh đề where của view. Nếu không dữ liệu sẽ chỉ kiểm tra các ràng buộc toàn vẹn của bảng.

CONSTRAINT Chỉ ra tên của điều kiện kiểm tra.

Ví dụ 1:

CREATE VIEW emp_view AS

SELECT empno, ename, sal FROM emp WHERE deptno = 10;

Ví dụ 2:

CREATE VIEW dept_summary

(name, minsal, maxsal, avsal) AS

SELECT dname, min(sal), max(sal), avg(sal) FROM emp, dept FROM emp, dept

WHERE emp.deptno = dept.deptno GROUP BY dname;

Ví dụ 3:

CREATE VIEW dept_view AS

SELECT eame, sal*12 Annsal FROM emp

WHERE deptno = 20

WITH CHECK OPTIION CONSTRAINT dept_check;

10.1.2. Xóa các view

Chỉ những người tạo view mới có quyền DROP

Trang 71

Oracle cơ bản - SQL và PL/SQL

DROP VIEW dept_view;

View có thể thực hiện các lệnh SQL sau:

SELECT

INSERT (insert trên view cũng ảnh hưởng lên table) Update (ảnh hưởng lên table)

Comment

Tuy nhiên có những ràng buộc sau:

Không thể insert, update trên view, khi query của view chứa các toán tử join, set, distinct, group by, group.

Không thể nào insert, update trên view, nếu như trong view có dùng with check option.

Không thể nào insert trên view, trên table có những cột not Null mà không dùng default value ( bởi vì trong trường hợp này view sẽ có ít colunm hơn table table. Nên insert 1 row vào view, thực chất là insert row đó vào table sẽ không hợp lệ).

Không thể nào insert trên view, nếu view này có dùng biểu thức decode.

Những query của view không thể nào tham khảo vào 2 column giả nextval, currval (nextval, currval dùng cho sequence).

10.2.BÀI TP

1. Tạo view có hiển thị như sau:

select * from aggredates;

DEPTNO AVERAGE MAXIMUN MINIMUN SUM NO_SALS NO_COMMS 10 2916.66667 5000 1300 8750 3 0 10 2916.66667 5000 1300 8750 3 0 20 2235 3300 800 11175 5 0 30 1566.66667 2850 950 9400 6 4

2. Tạo view để nhập số liệu vào bảng ASIGNMENT với các điều kiện sau:

PROJID <2000, P_START_DATE<P_END_DATE

Các giá trị có thể chấp nhận của assign_type là PS, WT hoặc ED

EMPNO có giá trị NOT NULL

BILL_RATE < 50 Với ASSIGN_TYPE Là PS BILL_RATE < 60 Với ASSIGN_TYPE Là WT BILL_RATE < 70 Với ASSIGN_TYPE Là ED

3. Định nghĩa bảng MESSAGES có cấu trúc

Column name Data Type NUMCOL1 NUMBER(9,2) NUMCOL2 NUMBER(9,2) CHARCOL1 VARCHAR2(60) CHARCOL2 VARCHAR2(60) DATECOL1 DATE DATECOL2 DATE

Oracle cơ bản - SQL và PL/SQL

Một phần của tài liệu Oracle PLSQL Language pot (Trang 74 - 76)

Tải bản đầy đủ (PDF)

(106 trang)