Oracle cơ bản - SQL và PL/SQL
Chương 3. TRUY VẤN DỮ LIỆU CÓ ĐIỀU KIỆN
3.1.CÁC GIỚI HẠN TRONG TRUY VẤN DỮ LIỆU
Trong phần lớn các trường hợp lấy dữ liệu từ database, ta chỉ cần lấy một phần dữ liệu chứ không cần lấy tất
cả. Để hạn chế các dữ liệu trả về không cần thiết, ta có thể sử dụng mệnh đề điều kiện trong câu lệnh truy
vấn.
Trang 17
Quyển sách này được upload tại: hutonline.netOracle cơ bản - SQL và PL/SQL
Truy vấn dữ liệu với nhiều điều kiện
Mệnh đề WHERE cho phép ghép được nhiều điều kiện thông qua các toán tử logic AND/OR. Toán tử AND
yêu cầu dữ liệu phải thoả mãn cả 2 điều kiện. Toán tử OR cho phép dữ liệu thoả mãn 1 trong 2 điều kiện.
Ví dụ:
SELECT DEPTNO, JOB, ENAME, SAL
FROM EMP
WHERE SAL BETWEEN 1000 AND 2000
AND JOB = ‘MANAGER’;
SELECT DEPTNO, JOB, ENAME, SAL
FROM EMP
WHERE SAL BETWEEN 1000 AND 2000
OR JOB = ‘MANAGER’;
SELECT DEPTNO, JOB, EMPNO, ENAME, SAL
FROM EMP
WHERE SAL > 1500
AND JOB = ‘MANAGER’
OR JOB =’SALESMAN’;
SELECT DEPTNO, JOB, EMPNO, ENAME, SAL
FROM EMP
WHERE SAL > 1500
AND (JOB = ‘MANAGER’
Toán tử nhỏ hơn
Toán tử lớn hơn hoặc bằng
Toán tử nhỏ hơn hoặc bằng
Diễn giải
[Không] lớn hơn hoặc bằng x và nhỏ hơn hoặc bằng y Thuộc bất kỳ giá
trị nào trong danh sách
Đúng nếu x [không] giống khung mẫu y
Các ký tự
dùng trong khuôn mẫu:
Dấu gạch dưới (_) : Chỉ một ký tự bất kỳ
Dấu phần trăm (%) : Chỉ một nhóm ký tự bất kỳ
Kiểm tra giá trị rỗng
Trả về TRUE nếu có tồn tại
Trang 18
Quyển sách này được upload tại: hutonline.netOracle cơ bản - SQL và PL/SQL
Các toán tử logic
Toán tử Diễn giải
NOT
Phủ định mệnh đề
AND
Yêu cầu dữ liệu phải thoả mãn cả 2 điều kiện
OR
Tìm tên phòng ban nếu phòng đó có nhân viên làm việc.
SELECT dname FROM dept WHERE EXISTS
(SELECT * FROM emp WHERE dept.deptno = emp.deptno); x [NOT] LIKE y
Tìm nhân viên có tên bắt đầu bằng chuỗi SMITH
SELECT * FROM emp WHERE
ename LIKE 'SMITH_';
Để chọn những nhân viên có tên bắt đầu bằng 'SM'
SELECT * FROM emp WHERE ename LIKE 'SM%'; Để tìm những nhân viên có tên có chuỗi 'A_B'
SELECT ename FROM emp WHERE ename LIKE '%A\_B%'; ESCAPE '\'
Vì ký hiệu "_" dùng để đại diện cho một ký tự bất kỳ nên nếu không có mệnh đề ESCAPE, câu lệnh trên sẽ
tìm tất cả các nhân viên tên AAB, ABB, ACB, v.v...
Nếu muốn ký hiệu "_" mang ý nghĩa nguyên thủy, tức là không còn đại diện cho ký tự bất kỳ nữa, ta đặt dấu
"\" trước ký hiệu. Đồng thời khai báo thêm mệnh đề ESCAPE "\"
Trang 19
Quyển sách này được upload tại: hutonline.netOracle cơ bản - SQL và PL/SQL
Ta cũng có thể dùng một ký tự bất kỳ thay cho "\". Chẳng hạn mệnh đề sau có cùng kết quả với mệnh đề trên
Ngày nhỏ trước
Ký tự theo bảng chữ cái
Để sắp xếp theo thứ tự ngược lại (giảm dần) đặt từ khoá DESC[ENDING] sau column cần sắp thứ tự.
Vi dụ:
SELECT ENAME, JOB, HIREDATE
FROM EMP
ORDER BY HIREDATE DESC ; 3.2.2.
Sắp xếp nhiều cột dữ liệu trả về
Mệnh đề Order còn có thể sắp xếp nhiều column. Các column cần sắp xếp được viết thứ tự sau mệnh đề
ORDER BY và cách bởi dấu phẩy (,). Column nào gần mệnh để ORDER BY hơn có mức độ ưu tiên khi sắp
xếp cao hơn. Chỉ định cách thức sắp xếp ASC/DESC được viết sau column cách bởi một dấ
u cách.
Ví dụ:
SELECT DEPTNO, JOB, ENAME, SAL Trang 20
Quyển sách này được upload tại: hutonline.netOracle cơ bản - SQL và PL/SQL
FROM EMP
ORDER BY DEPTNO, SAL DESC ;
30 SALES 3. Hiển thị danh sách những nhân viên làm tại phòng 10 và 20 theo thứ tự A,B,C
EMPNO ENAME JOB MGR HIREDATE SAL COMM DEPTNO
7876 ADAMS CLERK 7788 12-01-1983 1100 20
7782 CLARK MANAGER 7839 09-06-1981 2450 10
7902 FORD ANALYST 7566 03-12-1981 3000 20
7566 JONES MANAGER 7839 02-04-1981 2975 20
7839 KING PRESIDENT 17-11-1981 5000 10
7934 MILLER CLERK 7782 23-01-1982 1300 10
7788 SCOTT ANALYST 7566 09-12-1982 3000 20
7369 SMITH CLERK 7902 17-12-1980 800 20 4. Hiển thị tên và nghề nghiệp những nhân viên làm nghề thư ký (cleck) tại phòng 20.
ENAME JOB
SMITH CLERK
ADAMS CLERK
Trang 21
Quyển sách này được upload tại: hutonline.net