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.
Hình 22.1. Giao diện thêm mới dữ liệu
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.
Hình 22.2. Minh họa thao tác nhập dữ liệu
Trường idNhacsi là trường khóa 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.
Hình 22.3. Nhập dữ liệu cho trường khóa ngoài.
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.
Hình 22.4. Giao diện sửa dữ liệu
c. Xóa dữ liệu trong bảng bannhac
Thực hiện tương tự các bước ở Bài 21 để xóa các dòng dữ liệu trong bảng bannhac.
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ể tùy tiện xóa các dòng của bảng nhacsi. MySQL sẽ kiểm tra và ngăn chặn việc xóa các dòng trong bảng nhacsi mà giá trị trường idNhacsi đã có trong trường idNhacsi của bảng bannhac.
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 xóa dòng tương ứng với nhạc sĩ Văn Cao ở bảng nhacsi.
Hình 22.5. Minh họa xóa dữ liệu có tham chiếu.
Nếu chọn OK, thông báo lỗi sẽ xuất hiện như hình 22.6
Hình 22.6. Thông báo lỗi xóa dữ liệu làm mất tính toàn vẹn dữ liệu.
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 khóa 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 mẫn, mẫn cán trong công việc của mình.
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.
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 va cho nhận xét so sánh.
Hình 22.7. Giao diện Quản lí danh sách các bản nhạc
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.
- 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 có 10 dòng. Có thể nháy chuột vào hộp danh sách trang để chọn trang.
- 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.
- Muốn xóa 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 Xóa.
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 í 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, xóa, tìm kiếm được tích hợp vào một giao diện. 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?
--- THE END ---