Bài 6 TRUY XUẤT CSDL Ngôn ngữ thao tác dữ liệu – DMC và DCL pot

98 588 0
Bài 6 TRUY XUẤT CSDL Ngôn ngữ thao tác dữ liệu – DMC và DCL pot

Đang tải... (xem toàn văn)

Tài liệu hạn chế xem trước, để xem đầy đủ mời bạn chọn Tải xuống

Thông tin tài liệu

1 TRUY XUẤT CSDL Ngôn ngữ thao tác dữ liệuDMC DCL Bài 6 2 Accessing and Modifying Data 1. Truy xuất dữ liệu Lệnh Select Truy vấn đơn giản Truy vấn từ nhiều bảng Truy vấn con - SubQuery Các mệnh đề EXISTS, DISTINCT, COMPUTE BY 2. Sửa chữa dữ liệu Lệnh INSERT Lệnh UPDATE Lệnh DELETE 3 Cú pháp lệnh Select SELECT [ALL | DISTINCT] [TOP n [WITH TIES]] select_list [ INTO new_table ] FROM table_source [ WHERE search_condition ] [ GROUP BY group_by_expression ] [ HAVING search_condition ] [ ORDER BY order_expression [ ASC | DESC ] ] • ORDER BY : Sắp xếp • WHERE: Điều kiện • GROUP BY: Nhóm • HAVING: Điều kiện nhóm 4 Ví dụ lệnh SELECT Column names Table names Condition Sort order 5 Truy vấn đơn giản  Chọn tất cả các cột trong một bảng Syntax SELECT * FROM < tablename> SELECT * FROM Customers Example 6 Truy vấn đơn giản  Chọn một vài cột trong một bảng Syntax SELECT <column1>,<column2> FROM <tablename> SELECT Productid, productName FROM Products Example 7 Truy vấn đơn giản  Kết nối các cột thành một cột Syntax SELECT <column1>+<'constant' > FROM <tablename> SELECT FirstName + „ „ + Lastname FROM Employees Example 8 Truy vấn đơn giản  Đặt tên cho cột mới Syntax SELECT <column1> as <'alias'> FROM <tablename> SELECT FirstName +‟ „ +LastName AS „EmployeeName' FROM Employees Example 9  Tạo cột tính toán SELECT Orderid, Quantity*UnitPrice AS „Total' FROM [Order details] Example Truy vấn đơn giản 10  Loại bỏ những dòng trùng nhau Syntax SELECT DISTINCT <column1> FROM <tablename> SELECT DISTINCT Customerid FROM Orders Example Truy vấn đơn giản diadiem TP HCM HA NOI TP HCM diadiem TP HCM HA NOI SELECT diadiem FROM DIADIEM_PHG SELECT DISTINCT diadiem FROM DIADIEM_PHG [...]... (AVG(price) > 10) 32 Sử dụng WHERE HAVING • Mệnh đề HAVING giống như mệnh đề WHERE nhưng chỉ áp dụng cho cả nhóm trong khi mệnh đề WHERE áp dụng cho từng hàng • Một truy vấn có thể chứa cả mệnh đề WHERE mệnh đề HAVING Mệnh đề WHERE được áp dụng trước cho các hàng trong bảng được truy vấn Chỉ những hàng nào thoả mãn điều kiện của mệnh đề WHERE mới được nhóm dữ liệu – Sau đó mệnh đề HAVING sẽ được... 15000.0000 popular_comp NULL psychology NULL trad_cook 19000.0000 UNDECIDED NULL (6 row(s) affected) 31 GROUP BY HAVING • Có thể hạn chế các nhóm trong bảng kết quả bằng mệnh đề HAVING • Chỉ sau khi dữ liệu đã được nhóm tổng hợp , điều kiện trong mệnh đề HAVING mới được áp dụng • Không thể dùng 1 cột mà nó không tham gia vào hàm gộp của mệnh đề SELECT hay của mệnh đề GROUP BY • SELECT pub_id, AVG(price)... order_by_expression [ ASC | DESC ] } [ , n] ] ASC (ascending) : xếp theo thứ tự tăng DESC (descending): xếp theo thứ tự giảm 23 Nhóm dữ liệu trong bảng kết quả • Những mệnh đề dùng để nhóm dữ trong bảng kết quả: GROUP BY: tổng hợp bảng kết quả theo nhóm bằng cách dùng các hàm gộp COMPUTE COMPUTE BY: mệnh đề COMPUTE trong lệnh SELECT được dùng để phát ra các hàng tổng hợp bằng cách dùng hàm gộp Mệnh đề COMPUTE... 19 19 So sánh Chuỗi • So sánh gần đúng sử dụng “like” Hai ký tự thay thế: „_‟ „%‟ • Tìm tất cả các mã nhân viên có 3 ký tự cuoi cua dia chi la RD SELECT * FROM EMPLOYEES WHERE ADDRESS LIKE '%RD.' Cho biết tên nhân viên sinh vào những năm 1 960 SELECT LastName, FirstName, BirthDate FROM EMPLOYEES WHERE convert(char(8), BIRTHDATE,1) like ' 6_ ' 20 Các thuộc tính Trùng tên tuple variable Biến bộ.. .Truy vấn đơn giản  Chỉ có n hàng đầu tiên hay n% của các hàng của bảng kết quả được xuất Syntax SELECT TOP n [PERCENT] FROM Examples SELECT TOP 3 Productid, Unitprice FROM [Order Details] SELECT TOP 4 PERCENT Productid FROM Products 11 Mệnh đề WHERE • Chứa điều kiện lọc dữ liệu cần trả về • Cú pháp: WHERE ... BETWEEN…AND: giữa 2 giá trị IN: đạt giá trị trong 1 danh sách ALL/ ANY (SOME): được dùng trong lệnh truy vấn con kết quả là nhiều dòng ANY: Lớn hơn trị thấp nhất =ANY: Tương đương với IN >ALL: Lớn hơn trị cao nhất 10 34 Sử dụng WHERE HAVING Ví dụ 2 SELECT Productid, Sum(Quantity) As Total FROM [Order Details]... NV1.LASTNAME, NV2.LASTNAME,NV1.CITY EMPLOYEES NV1, EMPLOYEES NV2 WHERE NV1.CITY = NV2.CITY • Có thể sử dụng biến bộ bất kỳ lúc nào để thuận tiện dễ đọc! SELECT FROM NV1.LASTNAME, NV2.LASTNAME,NV1.CITY EMPLOYEES NV1, EMPLOYEES NV2 WHERE NV1.CITY NV2.CITY 21 Truy vấn từ nhiều bảng & Where (điều kiện kết nối) • Danh sách các hoá đơn gồm Mahd, tenkh SELECT orderid, Orderid.Customerid, CompanyName FROM... GROUP BY • Ví dụ: SELECT Orderid, SUM(Quantity * UnitPrice) AS „Total„ FROM [Order Details] GROUP BY Orderid SELECT Orderid, AVG(Quantity * UnitPrice) AS „AVG TOTAL„ FROM [Order Details] GROUP BY Orderid 26 Mệnh đề GROUP BY • Ví dụ: SELECT Orderid, MIN(Quantity * UnitPrice) AS „MIN Total„ FROM [Order Details] GROUP BY Orderid SELECT Orderid, MAX(Quantity * UnitPrice) AS „MAX Total„ FROM [Order Details] . 1 TRUY XUẤT CSDL Ngôn ngữ thao tác dữ liệu – DMC và DCL Bài 6 2 Accessing and Modifying Data 1. Truy xuất dữ liệu – Lệnh Select – Truy vấn đơn giản – Truy vấn từ nhiều bảng – Truy. Truy vấn từ nhiều bảng – Truy vấn con - SubQuery – Các mệnh đề EXISTS, DISTINCT, COMPUTE BY 2. Sửa chữa dữ liệu – Lệnh INSERT – Lệnh UPDATE – Lệnh DELETE 3 Cú pháp lệnh Select SELECT. Sort order 5 Truy vấn đơn giản  Chọn tất cả các cột trong một bảng Syntax SELECT * FROM < tablename> SELECT * FROM Customers Example 6 Truy vấn đơn giản  Chọn một vài cột trong

Ngày đăng: 27/06/2014, 06:20

Từ khóa liên quan

Tài liệu cùng người dùng

  • Đang cập nhật ...

Tài liệu liên quan