chuong 3
Chương III: Ngôn ngữ thao tác dữ liệu - DML Ths. Nguyễn Hồng Hạnh Chương III: Ngôn ngữ thao tác dữ liệu - DML Nội dung trình bày: Trong chương này sẽ đề cập đến nhóm các câu lệnh trong SQL được sử dụng để thực hiện các yêu cầu truy vấn và thao tác trên dữ liệu. Nhóm các câu lệnh này được gọi chung là ngôn ngữ thao tác dữ liệu (DML: Data Manipulation Language) bao gồm các câu lệnh sau: SELECT: Sử dụng để truy xuất dữ liệu từ một hoặc nhiều bảng. INSERT: Thêm/bổ sung dữ liệu. UPDATE: Cập nhật/sửa đổi dữ liệu DELETE: Xoá dữ liệu Trong đó, câu lệnh SELECT là câu lệnh được sử dụng nhiều trong cơ sở dữ liệu giúp thực hiện các yêu cầu thống kê dữ liệu phức tạp ngoài thao tác truy xuất đơn giản thường dùng. Chương III: Ngôn ngữ thao tác dữ liệu - DML 3.1 Nhóm câu lệnh thêm, sửa, xóa dữ liệu A.Thêm dữ liệu vào bảng Dữ liệu trong các bảng được thể hiện dưới dạng các dòng (bản ghi). Để bổ sung thêm các dòng dữ liệu vào một bảng, ta sử dụng câu lệnh INSERT. Hầu hết các hệ quản trị CSDL dựa trên SQL cung cấp các cách dưới đây để thực hiện thao tác thêm dữ liệu cho bảng: Thêm từng dòng dữ liệu vào bảng với mỗi câu lệnh INSERT. (thường gặp nhất). Thêm nhiều dòng dữ liệu bằng cách truy xuất dữ liệu từ các bảng dữ liệu khác. Chương III: Ngôn ngữ thao tác dữ liệu - DML 3.1 Nhóm câu lệnh thêm, sửa, xóa dữ liệu A.Thêm dữ liệu vào bảng Thêm từng dòng dữ liệu: Cú pháp câu lệnh như sau: INSERT INTO tên_bảng[(danh_sách_cột)] VALUES(danh_sách_giá_trị) Ví dụ: Chương III: Ngôn ngữ thao tác dữ liệu - DML 3.1 Nhóm câu lệnh thêm, sửa, xóa dữ liệu A.Thêm dữ liệu vào bảng Thêm từng dòng dữ liệu Chương III: Ngôn ngữ thao tác dữ liệu - DML 3.1 Nhóm câu lệnh thêm, sửa, xóa dữ liệu A.Thêm dữ liệu vào bảng Thêm từng dòng dữ liệu Chú ý: Chú ý: Thứ tự các giá trị phải trùng với thứ tự các cột Chỉ có thể thêm giá trị NULL ở những thuộc tính không là khóa chính hoặc được thiết lập Allow NULL khi tạo bảng. Cột được thiết lập identity sẽ tự động điền giá trị, trong câu lệnh INSERT không cần thiết lập giá trị cho cột này. Câu lệnh INSERT sẽ gặp lỗi nếu vi phạm các RBTV sau: Khóa chính Tham chiếu NOT NULL - các thuộc tính có ràng buộc NOT NULL bắt buộc phải có giá trị Chương III: Ngôn ngữ thao tác dữ liệu - DML 3.1 Nhóm câu lệnh thêm, sửa, xóa dữ liệu A.Thêm dữ liệu vào bảng Thêm một tập các dòng dữ liệu vào bảng Câu lệnh INSERT được sử dụng để bổ sung một tập các dòng dữ liệu được lấy từ một bảng khác nhờ câu lệnh SELECT. Cú pháp câu lệnh có dạng như sau: INSERT INTO tên_bảng[(danh_sách_cột)] câu_lệnh_SELECT Ví dụ: insert into Customers_Backup select * from Customers Lưu ý: Kết quả của câu lệnh SELECT phải có số cột bằng với số cột được chỉ định trong bảng đích và phải tương thích về kiểu dữ liệu. Chương III: Ngôn ngữ thao tác dữ liệu - DML 3.1 Nhóm câu lệnh thêm, sửa, xóa dữ liệu B.Cập nhật dữ liệu Câu lệnh UPDATE trong SQL được sử dụng để cập nhật dữ liệu trong các bảng. Cú pháp: UPDATE tên_bảng SET tên_cột = biểu_thức [, ., tên_cột_k = biểu_thức_k] [FROM danh_sách_bảng] [WHERE điều_kiện] Sau UPDATE là tên bảng cần cập nhật dữ liệu. Một câu lệnh UPDATE có thể cập nhật dữ liệu cho nhiều cột bằng cách chỉ định các danh sách tên cột và biểu thức tương ứng sau từ khoá SET. Mệnh đề WHERE trong câu lệnh UPDATE được sử dụng để chỉ định các dòng dữ liệu chịu tác động của câu lệnh (nếu không chỉ định, phạm vi tác động của câu lệnh được hiểu là toàn bộ các dòng trong bảng) Chương III: Ngôn ngữ thao tác dữ liệu - DML 3.1 Nhóm câu lệnh thêm, sửa, xóa dữ liệu B.Cập nhật dữ liệu Ví dụ: update customers set customername = 'Cao Van Chung' where customerid = 9 Trong câu lệnh UPDATE có thể sử dụng CASE…WHEN. Ví dụ: select * into tmp1 from customers update tmp1 set address = case when customerid < 2 then 'Nguyen Trung Truc' else 'Nguyen Thi Minh Khai' end Chương III: Ngôn ngữ thao tác dữ liệu - DML 3.1 Nhóm câu lệnh thêm, sửa, xóa dữ liệu C.Xóa dữ liệu Để xoá dữ liệu trong một bảng, sử dụng câu lệnh DELETE. Cú pháp của câu lệnh này như sau: DELETE FROM tên_bảng [FROM danh_sách_bảng] [WHERE điều_kiện] Trong đó: Tên của bảng cần xoá dữ liệu được chỉ định sau DELETE FROM. Mệnh đề WHERE trong câu lệnh được sử dụng để chỉ định điều kiện đối với các dòng dữ liệu cần xoá. Nếu câu lệnh DELETE không có mệnh đề WHERE thì toàn bộ các dòng dữ liệu trong bảng đều bị xoá. Ví dụ: delete from Items where itemid = 3 [...]... select [Mã khách hàng] = Customerid, customername as [Tên khách hàng], address [Địa chỉ] from Customers Chương III: Ngôn ngữ thao tác dữ liệu - DML 3.2 Câu lệnh truy xuất dữ liệu SELECT Phép toán đổi tên (SQL Alias) với từ khóa AS Ví dụ: Nếu không dùng phép đổi tên: Chương III: Ngôn ngữ thao tác dữ liệu - DML 3.2 Câu lệnh truy xuất dữ liệu SELECT A.Danh sách chọn sau từ khóa SELECT Sử dụng cấu trúc CASE…WHEN: . Nội dung trình bày: Trong chương này sẽ đề cập đến nhóm các câu lệnh trong SQL được sử dụng để thực hiện các yêu cầu truy vấn và thao tác trên dữ liệu.. một bảng, ta sử dụng câu lệnh INSERT. Hầu hết các hệ quản trị CSDL dựa trên SQL cung cấp các cách dưới đây để thực hiện thao tác thêm dữ liệu cho bảng: