Chức năng:

Rút trích các dòng dữ liệu từ các quan hệ tham gia truy vấn thỏa mãn điều kiện trong mệnh đề WHERE. Các biểu thức trong mệnh đề WHERE tương ứng với các điều kiện của phép chọn trong đại số quan hệ.

Cú pháp:

SELECT [DISTINCT] *|DANH_SACH_THUOC_TINH|BIEU_THUC,...
FROM DANH_SACH_QUAN_HE
WHERE BIEU_THUC_DIEU_KIEN

Trong đó:

+ DANH_SACH_THUOC_TINH: bao gồm tất cả các cột muốn rút trích thông tin từ quan hệ trong cơ sở dữ liệu. Các thuộc tính cách nhau bởi dấu ",". Các thuộc tính trùng tên phải đặt tên quan hệ gắn liền với thuộc tính đó (theo quy tắc TEN_QUAN_HE.TEN_THUOC_TINH).

+ DANH_SACH_QUAN_HE: bao gồm tất cả các quan hệ tham gia hỗ trợ thực hiện yêu cầu truy vấn. Các quan hệ cách nhau bởi dấu ",".

+ BIEU_THUC_DIEU_KIEN: các dòng dữ liệu được rút trích ra từ cơ sở dữ liệu phải thỏa mãn các biểu thức điều kiện đã được quy định trong mệnh đề WHERE. Các điều kiện được nối với nhau bởi AND/OR.

Ví dụ minh họa

Để thuận tiện cho các bạn học tập, mình có tạo sẵn file .sql trong này đã mình tạo cấu trúc bảng và data sẵn để các bạn dễ dàng thực hiện truy vấn, các bạn có thể tải tại đây.

Ví dụ 1: Hãy cho biết họ và tên các nhân viên có mức lương trên 30000.

SELECT MANV, HONV, TENLOT, TENNV
FROM NHANVIEN
WHERE LUONG > 30000

Kết quả:

Ví dụ 2: Hãy cho biết họ và tên các nhân viên có mức lương từ 40000 đến 70000

SELECT MANV, HONV, TENLOT, TENNV
FROM NHANVIEN
WHERE LUONG >= 40000 AND LUONG <= 70000

Kết quả:

Ví dụ 3: Hãy cho biết họ và tên các nhân viên cùng tên phòng mà nhân viên đó trực thuộc.

SELECT MANV, HONV, TENLOT, TENNV, TENPHG
FROM NHANVIEN, PHONGBAN
WHERE PHG = MAPHG

Kết quả:

Ví dụ 4: Hãy cho biết họ và tên các nhân viên nữ có mức lương < 30000 hoặc có mức lương trên 50000.

SELECT MANV, HONV, TENLOT, TENNV
FROM NHANVIEN
WHERE PHAI = 'Nu' AND (LUONG < 30000 OR LUONG > 50000)

Kết quả:

Ví dụ 5: Hãy cho biết họ và tên các nhân viên có mức lương từ 40000 đến 70000 (sử dụng toán tử BETWEEN ... AND ...)

SELECT MANV, HONV, TENLOT, TENNV
FROM NHANVIEN
WHERE LUONG BETWEEN 40000 AND 70000

Kết quả:

Ví dụ 6: Hãy cho biết họ và tên các nhân viên nữ có mức lương < 30000 hoặc có mức lương trên 50000 (sử dụng toán tử NOT BETWEEN ... AND ...)

SELECT MANV, HONV, TENLOT, TENNV
FROM NHANVIEN
WHERE PHAI = 'Nu' AND (LUONG NOT BETWEEN 30000 AND 50000)

Kết quả:

Ví dụ 7: Hãy cho biết họ và tên nhân viên có họ là 'NGUYEN'.

Cách 1:

SELECT MANV, HONV, TENLOT, TENNV
FROM NHANVIEN
WHERE HONV = 'NGUYEN'

Kết quả:

Cách 2:

SELECT MANV, HONV, TENLOT, TENNV
FROM NHANVIEN
WHERE HONV LIKE 'NGUYEN'

Kết quả:

Ví dụ 8: Hãy cho biết họ và tên tất cả nhân viên có họ bắt đầu là kí tự N.

Trong trường hợp chỉ so sánh một hoặc một vài ký tự được trích ra từ một chuỗi (tức là chuỗi có giá trị không trọn vẹn) ta không thể sử dụng toán tử '=' hoặc '<>' để so sánh mà phải sử dụng toán tử LIKE hoặc NOT LIKE.

Khi sử dụng LIKE./NOT LIKE, người ta quy ước như sau:

+ dấu '%': đại diện cho một chuỗi con bất kỳ.

+ dấu '_': đại diện cho một ký tự bất kỳ.

Câu truy vấn như sau:

SELECT MANV, HONV, TENLOT, TENNV
FROM NHANVIEN
WHERE HONV LIKE 'N%'

Kết quả:

Ví dụ 9: Hãy cho biết họ và tên tất cả các nhân viên có họ bắt đầu là ký tự N, sau ký tự N là 2 ký tự.

SELECT MANV, HONV, TENLOT, TENNV
FROM NHANVIEN
WHERE HONV LIKE 'N__'

Kết quả:

CÓ THỂ BẠN QUAN TÂM

SQL Server - Backup / Restore Database

SQL Server - Backup / Restore Database

Mục đích của việc sao lưu và phục hồi dữ liệu Sao lưu và phục hồi dữ liệu là vấn đề rất quan trọng khi quản trị cơ sở dữ liệu. Hoạt động này đảm bảo cho dữ liệu khi xảy ra sự cố, ta có thể khôi phục...

T SQL - Cấu trúc CASE

T SQL - Cấu trúc CASE

Biểu thức CASE là một biểu thức điều kiện được áp dụng bên trong một biểu thức khác. CASE trả về các giá trị khác nhau tùy thuộc vào điều kiện.

SQL Server - Table

SQL Server - Table

Trong cơ sở dữ liệu, để tạo và quản trị các bảng dữ liệu, người dùng cần phải trả lời các câu hỏi sau: + Bảng dùng để lưu trữ những thông tin gì? Nên đặt tên bảng mang tính chất gợi nhớ tương ứng v...

SQL Server - Stored Procedure

SQL Server - Stored Procedure

Khái niệm Stored Procedure - SP (thủ tục) là một tập các lệnh T -SQL và một số cấu trúc điều khiển, được lưu với một tên và được thực thi như một đơn vị công việc (Single unit of work) . Một thủ tục...

SQL Server - Lệnh UPDATE

SQL Server - Lệnh UPDATE

Chức năng: cho phép người dùng cập nhật giá trị các thuộc tính trên các dòng của bảng dữ liệu có sẵn trong cơ sở dữ liệu.

SQL Server - Lệnh INSERT

SQL Server - Lệnh INSERT

Chức năng: cho phép thêm một hoặc nhiều dòng dữ liệu vào bảng đã tạo sẵn trong cơ sở dữ liệu.

Lập trình T SQL

Lập trình T SQL

T-SQL (Transact SQL) là ngôn ngữ lập trình cơ sở dữ liệu thủ tục độc quyền của Microsoft dành cho SQL Server. Chúng cũng được sử dụng để viết các thủ tục được lưu trữ, là một đoạn mã nằm trên máy chủ...

T SQL - Cấu trúc WHILE

T SQL - Cấu trúc WHILE

Câu lệnh WHILE là một cấu trúc lặp sẽ thực hiện các thao tác lặp cho đến khi biểu thức điều kiện trong câu lệnh WHILE có giá trị Fasle. Biểu thức điều kiện lặp lại có thể là một câu lệnh SELECT

SQL Server - Lệnh DELETE

SQL Server - Lệnh DELETE

Chức năng: cho phép người dùng xóa một hoặc nhiều dòng dữ liệu trên bảng dữ liệu đã có sẵn trong cơ sở dữ liệu.

ManhDanBlogs