SQL Server _03

75 559 5
Tài liệu đã được kiểm tra trùng lặp
SQL Server _03

Đ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

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:

Ngày đăng: 05/05/2013, 07:25

Hình ảnh liên quan

A.Thêm dữ liệu vào bảng - SQL Server _03

h.

êm dữ liệu vào bảng Xem tại trang 4 của tài liệu.
A.Thêm dữ liệu vào bảng - SQL Server _03

h.

êm dữ liệu vào bảng Xem tại trang 5 của tài liệu.
UPDATE tên_bảng - SQL Server _03

t.

ên_bảng Xem tại trang 8 của tài liệu.
Các bảng dữ liệu trong CSDL Test - SQL Server _03

c.

bảng dữ liệu trong CSDL Test Xem tại trang 13 của tài liệu.
thứ tự mà chúng được tạo ra khi định nghĩa bảng. Ví dụ:  Select * from Customers - SQL Server _03

th.

ứ tự mà chúng được tạo ra khi định nghĩa bảng. Ví dụ: Select * from Customers Xem tại trang 14 của tài liệu.
Lưu ý: Nếu truy vấn được thực hiện trên nhiều bảng/khung nhìn hoặc 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: - SQL Server _03

u.

ý: Nếu truy vấn được thực hiện trên nhiều bảng/khung nhìn hoặc 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: Xem tại trang 15 của tài liệu.
là tên của các trường tương ứng trong bảng. Để các tiêu đề trở nên thân thiện hơn, có thể đổi tên tiêu đề của các cột bằng 2 cách viết: - SQL Server _03

l.

à tên của các trường tương ứng trong bảng. Để các tiêu đề trở nên thân thiện hơn, có thể đổi tên tiêu đề của các cột bằng 2 cách viết: Xem tại trang 16 của tài liệu.
Từ khóa DISTINCT sẽ loại bỏ các dòng dữ liệu giống nhau. Trong bảng Customers có  hai khách hàng trùng tên “Cao Van Trung” - SQL Server _03

kh.

óa DISTINCT sẽ loại bỏ các dòng dữ liệu giống nhau. Trong bảng Customers có hai khách hàng trùng tên “Cao Van Trung” Xem tại trang 20 của tài liệu.
Mệnh đề FROM trong câu lệnh SELECT được sử dụng nhằm chỉ định các bảng và  khung nhìn  cần  truy  xuất  dữ  liệu - SQL Server _03

nh.

đề FROM trong câu lệnh SELECT được sử dụng nhằm chỉ định các bảng và khung nhìn cần truy xuất dữ liệu Xem tại trang 21 của tài liệu.
a. Tìm kiếm không điều kiện trên một bảng - SQL Server _03

a..

Tìm kiếm không điều kiện trên một bảng Xem tại trang 28 của tài liệu.
FROM &lt;danh sách các bảng&gt; - SQL Server _03

lt.

;danh sách các bảng&gt; Xem tại trang 31 của tài liệu.
h. Tìm kiếm có phân nhóm các bản ghi kết quả: bảng Orders - SQL Server _03

h..

Tìm kiếm có phân nhóm các bản ghi kết quả: bảng Orders Xem tại trang 45 của tài liệu.
3.2 Câu lệnh truy xuất dữ liệu SELECT - SQL Server _03

3.2.

Câu lệnh truy xuất dữ liệu SELECT Xem tại trang 45 của tài liệu.
3.2 Câu lệnh truy xuất dữ liệu SELECT - SQL Server _03

3.2.

Câu lệnh truy xuất dữ liệu SELECT Xem tại trang 48 của tài liệu.
Bảng chữ viết tắt và các yêu cầu trích xuất tương ứng: - SQL Server _03

Bảng ch.

ữ viết tắt và các yêu cầu trích xuất tương ứng: Xem tại trang 65 của tài liệu.
tên_bảng_1 [INNER] JOIN tên_bảng_2 ON điều_kiện_nối - SQL Server _03

t.

ên_bảng_1 [INNER] JOIN tên_bảng_2 ON điều_kiện_nối Xem tại trang 71 của tài liệu.

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

Tài liệu liên quan