3 Ngôn ngữ thao tác dữ liệu – DML
3.1.1 Danh sách chọn trong câu lệnh SELECT
Danh sách chọn trong câu lệnh SELECT được sử dụng để chỉ định các tr ường, các biểu thức cần hiển thị trong các cột của kết quả truy vấn. Các tr ường, các biểu thức được chỉ định ngay sau từ khoá SELECT và phân cách nhau bởi dấu phẩy. Sử dụng danh sách chọn trong câu lệnh SELECT bao gồm các t rường hợp sau:
Chọn tất cả các cột: Như đã nói trong chương 1, chúng ta dùng dấu * trong câu lệnh Select để hàm ý chọn hết tất cả các cột. Trong trường hợp này, các cột được hiển thị trong kết quả truy vấn sẽ tuân theo thứ tự m à chúng đã được tạo ra khi bảng được định nghĩa.
Ví dụ:
Select * from Customers
Chọn một số cột cụ thể: Trong trường hợp cần chỉ định cụ thể các cột cần hiển thị trong kết quả truy vấn, ta chỉ định danh sách các t ên cột trong danh sách chọn. Thứ tự của các cột trong kết quả truy vấn tuân theo thứ tự của các trường trong danh sách chọn.
Ví dụ:
Select CUSTOMERNAME, ADDRESS From Customers
Lưu ý: Nếu truy vấn được thực hiện trên nhiều bảng/khung nhìn và trong các bảng/khung nhìn có các trường trùng tên thì tên của những trường này nếu xuất hiện trong danh sách chọn phải được viết dưới dạng:
tên_bảng.tên_trường
Thay đổi tiêu đề các cột:
Trong kết quả truy vấn, tiêu đề của các cột mặc định sẽ l à tên của các trường tương ứng trong bảng. Tuy nhiên, để các tiêu đề trở nên thân thiện hơn, ta có thể đổi tên các tiêu đề của các cột. Để đặt tiêu đề cho một cột nào đó, ta sử dụng cách viết:
tiêu_đề_cột = tên_trường hoặc tên_trường AS tiêu_đề_cột hoặc
32 Ví dụ: select [Mã khách hàng] = Customerid, customername as [Tên khách hàng], address [Địa chỉ] from Customers Sử dụng cấu trúc CASE…WHEN:
Cấu trúc CASE được sử dụng trong danh sách chọn nhằm thay đổi kết quả của truy vấn tuỳ thuộc vào các trường hợp khác nhau. Cấu trúc n ày có cú pháp như sau:
CASE biểu_thức
WHEN biểu_thức_kiểm_tra THEN kết_quả [ ... ]
[ELSE kết_quả_của_else] END
hoặc: CASE
WHEN điều_kiện THEN kết_quả [ ... ]
[ELSE kết_quả_của_else] END
Ví dụ: Câu lệnh SQL dưới đây sẽ hiện thị giới tính của khách h àng tùy theo giá trị thực được lưu trong CSDL. Nếu giá trị trong CSDL là FALSE-> hiện thị giới tính NỮ, nếu giá trị l à TRUE-> hiện thị giới tính NAM.
select CUSTOMERNAME, ADDRESS, case GENDER
when 1 then 'NAM' else N'NỮ'
end as [GIỚI TÍNH] from customers
select CUSTOMERNAME, ADDRESS, case
when GENDER = 1 then 'NAM' else N'NỮ'
end as [GIỚI TÍNH] from customers
Loại bỏ các dòng dữ liệu trùng nhau:
Từ khóa DISTINCT sẽ loại bỏ các d òng dữ liệu giống nhau. Trong ví dụ tr ên, có hai khách hàng có tên Cao Van Trung. Nếu ta chỉ truy vấn tên khách hàng, để loại bỏ sự trùng lắp ta dùng từ khóa DISTINCT
select distinct CUSTOMERNAME
from customers
Lựa chọn một số lượng giới hạn các dòng: Từ khóa TOP n sẽ trả về chỉ n d òng dữ liệu
Ví dụ: ví dụ sau chỉ trả về duy nhất hai dòng dữ liệu
select top 2 Customername from customers
34