Sách kết nối tri thức – Định hướng tin học ứng dụng.
Website: thaycai.net Youtube: Thầy Cải-Quốc Thái-An Giang
Khi cập nhật một bảng có khoá ngoài, dữ liệu của trường khoá ngoài phải là dữ liệu tham chiếu được đến một trường khoá chính của một bảng tham chiếu. HeidiSQL hỗ trợ kiểm soát điều này như thế nào?
Website: thaycai.net Youtube: Thầy Cải-Quốc Thái-An Giang
Gợi ý trả lời:
HeidiSQL hỗ trợ kiểm soát khóa ngoài trong quá trình cập nhật dữ liệu trên bảng, giúp đảm bảo tính nhất quán và tính toàn vẹn của dữ liệu trong CSDL.
Website: thaycai.net Youtube: Thầy Cải-Quốc Thái-An Giang
Nhiệm vụ 1. Cập nhật bảng bannhac
Hướng dẫn:
a) Thêm mới dữ liệu vào bảng bannhac
Chọn bảng bannhac, nháy chuột chọn thẻ Dữ liệu, em sẽ thấy bảng dữ liệu có các trường idBannhac, tenBannhac, idNhacsi nhưng chưa có dữ liệu.
Website: thaycai.net Youtube: Thầy Cải-Quốc Thái-An Giang
Website: thaycai.net Youtube: Thầy Cải-Quốc Thái-An Giang
Thực hiện nhập dữ liệu.
Trường idNhacsi có kiểu INT, AUTO_INCREMENT nên không cần nhập dữ liệu cho trường này. Nháy đúp chuột vào ô ở trường tenBannhac để nhập tên bản nhạc.
Website: thaycai.net Youtube: Thầy Cải-Quốc Thái-An Giang
Website: thaycai.net Youtube: Thầy Cải-Quốc Thái-An Giang
Trường idNhacsi là trường khoá ngoài, đã được khai báo tham chiếu đến trường idNhacsi của bảng nhacsi, vì vậy để đảm bảo tính nhất quán, giá trị hợp lệ chỉ có thể lấy từ các giá trị của idNhacsi có trong bảng nhacsi. Nháy đúp chuột vào ô nhập trường idNhacsi và chọn tên nhạc sĩ trong hộp danh sách.
Website: thaycai.net Youtube: Thầy Cải-Quốc Thái-An Giang
Website: thaycai.net Youtube: Thầy Cải-Quốc Thái-An Giang
b) Sửa chửa, cập nhật dữ liệu trong bảng bannhac
Thao tác sửa chữa dữ liệu trong bảng bannhac nếu phát hiện có sai sót, tương tự như đã được giới thiệu ở Bài 21, chỉ cần nháy đúp chuột vào ô dữ liệu muốn sửa.
Sửa dữ liệu trường idNhacsi ở dòng số 2.
Website: thaycai.net Youtube: Thầy Cải-Quốc Thái-An Giang
Website: thaycai.net Youtube: Thầy Cải-Quốc Thái-An Giang
c) Xóa dữ liệu trong bảng bannhac
Thực hiện tương tự các bước ở Bài 21 để xoá các dòng dữ liệu trong bảng bannhac.
Website: thaycai.net Youtube: Thầy Cải-Quốc Thái-An Giang
d) Xóa dữ liệu trong bảng nhacsi
Chú ý rằng bây giờ bảng bannhac đã có dữ liệu với trường idNhacsi tham chiếu đến trường idNhacsi của bảng nhacsi. Do vậy, ta sẽ không thể tuỳ tiện xoá các dòng của bảng nhacsi. MySQL sẽ kiểm tra và ngăn chặn việc xoá các dòng trong bảng nhacsi mà giá trị trường idNhacsi đã có trong trường idNhacsi của bảng bannhac.
Website: thaycai.net Youtube: Thầy Cải-Quốc Thái-An Giang
Ví dụ: idNhacsi của nhạc sĩ Văn Cao là 2 đã có trong các bản nhạc Trường ca sông Lô, Tiến về Hà Nội ở bảng bannhac. MySQL sẽ ngăn chặn xoá dòng tương ứng với nhạc sĩ Văn Cao ở bảng nhacsi.
Website: thaycai.net Youtube: Thầy Cải-Quốc Thái-An Giang
Nếu chọn OK, thông báo lỗi sẽ xuất hiện như Hình 22.6
Website: thaycai.net Youtube: Thầy Cải-Quốc Thái-An Giang
Website: thaycai.net Youtube: Thầy Cải-Quốc Thái-An Giang
Lưu ý: Hệ QTCSDL chỉ có thể ngăn chặn được các lỗi theo lôgic đã được khai báo (ví dụ lôgic tham chiếu khoá ngoài). Nó không thể ngăn chặn được các lỗi không liên quan đến lôgic nào. Ví dụ: Chọn tên nhạc sĩ sáng tác bản nhạc Hà Nội niềm tin và hi vọng là Phan Nhân hay Đỗ Nhuận thì không sai về lôgic; nếu các em nhập sai tên bản nhạc, tên người (tên nhạc sĩ, ca sĩ) thì lỗi này sẽ xuất hiện ở tất cả các danh sách kết xuất liên quan như bản nhạc, bản thu âm. Vì vậy người làm việc với CSDL luôn phải có sự cẩn thận, mẫn cán trong công việc của mình.
Website: thaycai.net Youtube: Thầy Cải-Quốc Thái-An Giang
e) Truy xuất dữ liệu trong bảng bannhac
Việc truy xuất dữ liệu trong bảng bannhac là hoàn toàn tương tự như truy xuất dữ liệu trong bảng nhacsi ở Bài 21.
- Hãy thực hành các truy xuất dữ liệu theo thứ tự giảm dần của trường idBannhac, theo thứ tự tên các bản nhạc.
- Hãy thực hành lấy ra danh sách tên các bản nhạc của nhạc sĩ Văn Cao có trong bảng bannhac.
Website: thaycai.net Youtube: Thầy Cải-Quốc Thái-An Giang
Nhiệm vụ 2.
Hãy tìm hiểu một chức năng của phần mềm ứng dụng Quản lí dữ liệu âm nhạc qua giao diện ở Hình 22.7, so sánh với những kiến thức vừa được học trong bài thực hành và cho nhận xét so sánh.
Website: thaycai.net Youtube: Thầy Cải-Quốc Thái-An Giang
Website: thaycai.net Youtube: Thầy Cải-Quốc Thái-An Giang
Cách tương tác với giao diện này như sau:
- Để nhập dữ liệu bản nhạc mới, người dùng phải nhập tên bản nhạc, chọn nhạc sĩ từ hộp danh sách phía dưới sau đó chọn Nhập. Ví dụ nhập “Hà Nội niềm tin và hi vọng”, chọn nhạc sĩ Phan Nhân và nháy chuột chọn Nhập.
- Để tìm một bản nhạc có thể nhập vài từ của tên bản nhạc, cũng có thể chọn nhạc sĩ nếu biết, sau đó nháy chuột chọn Tìm.
Website: thaycai.net Youtube: Thầy Cải-Quốc Thái-An Giang
- Danh sách các bản nhạc đã có trong CSDL được thể hiện ở bảng phía dưới thành nhiều trang, mỗi trang 10 dòng. Có thể nháy chuột vào hộp danh sách trang để chọn trang.
Website: thaycai.net Youtube: Thầy Cải-Quốc Thái-An Giang
- Muốn sửa một bản nhạc nào đó, nháy chuột vào phím radio ( ) trên dòng đó, thông tin của bản nhạc sẽ được hiển thị ở phần phía trên của giao diện để người dùng sửa chữa, thay đổi,... Nháy chuột chọn Nhập để lưu lại kết quả thay đổi.
Website: thaycai.net Youtube: Thầy Cải-Quốc Thái-An Giang
- Muốn xoá một hay nhiều bản nhạc nào đó trong danh sách đã có: nháy chuột vào các checkbox ở đầu các dòng tương ứng và chọn Xoá.
Website: thaycai.net Youtube: Thầy Cải-Quốc Thái-An Giang
Hướng dẫn:
Ứng dụng Quản lí dữ liệu âm nhạc nói trên là một ứng dụng được thiết kế chuyên biệt cho bài toán quản lí dữ liệu âm nhạc, giao diện được thiết kế hướng vào những nghiệp vụ mà người quản lí thường phải làm hằng ngày (không phải là giao diện hướng vào từng bảng dữ liệu). Tất cả các chức năng nhập mới, sửa chữa, xoá, tìm kiếm được tích hợp vào một giao diện.
Website: thaycai.net Youtube: Thầy Cải-Quốc Thái-An Giang
Theo các em:
- Người sử dụng có cần biết, nhớ cấu trúc của bảng bannhac, bảng nhacsi không?
- Giao diện trên có dễ hiểu, dễ sử dụng không?
Website: thaycai.net Youtube: Thầy Cải-Quốc Thái-An Giang
Luyện tập 1 (trang 108): Cập nhật dữ liệu vào bảng banthuam.
Website: thaycai.net Youtube: Thầy Cải-Quốc Thái-An Giang
Website: thaycai.net Youtube: Thầy Cải-Quốc Thái-An Giang
Gợi ý cách thực hiện:
Bước 1. Nháy chọn bảng banthuam (đã tạo ở bài thực hành trước).
Bước 2. Nháy vào Dữ liệu.
Website: thaycai.net Youtube: Thầy Cải-Quốc Thái-An Giang
Website: thaycai.net Youtube: Thầy Cải-Quốc Thái-An Giang
Bước 3. Nháy vào nút dấu cộng (+), nhập dữ liệu như bên dưới:
Website: thaycai.net Youtube: Thầy Cải-Quốc Thái-An Giang
Lưu ý: Trường idBanthuam không cần phải nhập dữ liệu, vì ta đã chọn kiểu dữ liệu INT và AUTO_INCREMENT (nghĩa là kiểu dữ liệu số nguyên và tự động tăng).
Website: thaycai.net Youtube: Thầy Cải-Quốc Thái-An Giang
Luyện tập 2 (trang 108): Truy xuất dữ liệu bảng banthuam theo các tiêu chí khác nhau.
Website: thaycai.net Youtube: Thầy Cải-Quốc Thái-An Giang
Gợi ý cách thực hiện:
1. Truy xuất tất cả các dòng dữ liệu từ bảng banthuam:
Website: thaycai.net Youtube: Thầy Cải-Quốc Thái-An Giang
(1) Nháy chọn Truy vấn.
(2) Nhập câu lệnh SQL.
(3) Nháy nút Thực hiện truy vấn (F9).
(4) Kết quả hiển thị.
Website: thaycai.net Youtube: Thầy Cải-Quốc Thái-An Giang
2. Truy xuất dữ liệu từ bảng banthuam với điều kiện idbannhac =1
Website: thaycai.net Youtube: Thầy Cải-Quốc Thái-An Giang
a) Thêm mới dữ liệu vào bảng bannhac
b) Sửa chữa, cập nhật dữ liệu trong bảng bannhac
Nhiệm vụ 1. Cập nhật bảng bannhac
c) Xóa dữ liệu trong bảng bannhac
d) Xóa dữ liệu trong bảng nhacsi
e) Truy xuất dữ liệu trong bảng bannhac
Nhiệm vụ 2.
Website: thaycai.net Youtube: Thầy Cải-Quốc Thái-An Giang
1. Làm phần VẬN DỤNG (SGK trang 108)
2. Xem trước bài 23 (SGK trang 109)
Thực hành truy xuất dữ liệu qua liên kết các bảng
Website: thaycai.net Youtube: Thầy Cải-Quốc Thái-An Giang
Các em làm 10 câu hỏi trắc nghiệm Online để củng cố bài.
1. Đăng nhập vào trang thaycai.net
2. Nháy chọn Tin học 11
3. Nháy chuột vào Trắc nghiệm tin học 11 - Kết nối tri thức
4. Nháy chuột vào Bài 22. Thực hành cập nhật bảng dữ liệu có tham chiếu
Website: thaycai.net Youtube: Thầy Cải-Quốc Thái-An Giang