Để thiết kế một cơ sở dữ liệu quản lý thư viện cho một trường học, chúng ta sẽ xác định các đối tượng cần quản lý và tạo các bảng tương ứng. Dưới đây là các bước thực hiện:
### 1. Xác định các đối tượng cần quản lý
- **Sách (Books)**
- **Độc giả (Readers)**
- **Mượn trả sách (Borrow_Return)**
- **Tác giả (Authors)**
- **Nhà xuất bản (Publishers)**
### 2. Thiết kế các bảng
#### Bảng 1: Sách (Books)
- **Tên bảng**: `Books`
- **Các trường**:
- `BookID` (INT, Khóa chính)
- `Title` (VARCHAR(255))
- `AuthorID` (INT, Khóa ngoài)
- `PublisherID` (INT, Khóa ngoài)
- `PublishedYear` (YEAR)
- `Quantity` (INT)
#### Bảng 2: Độc giả (Readers)
- **Tên bảng**: `Readers`
- **Các trường**:
- `ReaderID` (INT, Khóa chính)
- `Name` (VARCHAR(255))
- `Class` (VARCHAR(50))
- `DateOfBirth` (DATE)
#### Bảng 3: Mượn trả sách (Borrow_Return)
- **Tên bảng**: `Borrow_Return`
- **Các trường**:
- `TransactionID` (INT, Khóa chính)
- `BookID` (INT, Khóa ngoài)
- `ReaderID` (INT, Khóa ngoài)
- `BorrowDate` (DATE)
- `ReturnDate` (DATE)
#### Bảng 4: Tác giả (Authors)
- **Tên bảng**: `Authors`
- **Các trường**:
- `AuthorID` (INT, Khóa chính)
- `AuthorName` (VARCHAR(255))
#### Bảng 5: Nhà xuất bản (Publishers)
- **Tên bảng**: `Publishers`
- **Các trường**:
- `PublisherID` (INT, Khóa chính)
- `PublisherName` (VARCHAR(255))
### 3. Sơ đồ cơ sở dữ liệu (Database Diagram)
```
+----------------+ +----------------+ +----------------+
| Authors | | Publishers | | Books |
+----------------+ +----------------+ +----------------+
| AuthorID (PK) |<----- | PublisherID (PK)|<----- | BookID (PK) |
| AuthorName | | PublisherName | | Title |
+----------------+ +----------------+ | AuthorID (FK) |
| PublisherID (FK)|
| PublishedYear |
| Quantity |
+----------------+
|
|
|
+----------------+
| Borrow_Return |
+----------------+
| TransactionID (PK)|
| BookID (FK) |
| ReaderID (FK) |
| BorrowDate |
| ReturnDate |
+----------------+
|
|
+----------------+
| Readers |
+----------------+
| ReaderID (PK) |
| Name |
| Class |
| DateOfBirth |
+----------------+
```
### 4. Câu truy vấn SQL
#### Khởi tạo cơ sở dữ liệu
```sql
CREATE DATABASE LibraryManagement;
USE LibraryManagement;
```
#### Khởi tạo các bảng
```sql
CREATE TABLE Authors (
AuthorID INT PRIMARY KEY,
AuthorName VARCHAR(255)
);
CREATE TABLE Publishers (
PublisherID INT PRIMARY KEY,
PublisherName VARCHAR(255)
);
CREATE TABLE Books (
BookID INT PRIMARY KEY,
Title VARCHAR(255),
AuthorID INT,
PublisherID INT,
PublishedYear YEAR,
Quantity INT,
FOREIGN KEY (AuthorID) REFERENCES Authors(AuthorID),
FOREIGN KEY (PublisherID) REFERENCES Publishers(PublisherID)
);
CREATE TABLE Readers (
ReaderID INT PRIMARY KEY,
Name VARCHAR(255),
Class VARCHAR(50),
DateOfBirth DATE
);
CREATE TABLE Borrow_Return (
TransactionID INT PRIMARY KEY,
BookID INT,
ReaderID INT,
BorrowDate DATE,
ReturnDate DATE,
FOREIGN KEY (BookID) REFERENCES Books(BookID),
FOREIGN KEY (ReaderID) REFERENCES Readers(ReaderID)
);
```
#### Cập nhật dữ liệu vào tất cả các bảng
```sql
-- Thêm dữ liệu vào bảng Authors
INSERT INTO Authors (AuthorID, AuthorName) VALUES (1, 'Nguyễn Nhật Ánh');
INSERT INTO Authors (AuthorID, AuthorName) VALUES (2, 'Tô Hoài');
INSERT INTO Authors (AuthorID, AuthorName) VALUES (3, 'Lê Minh Khuê');
-- Thêm dữ liệu vào bảng Publishers
INSERT INTO Publishers (PublisherID, PublisherName) VALUES (1, 'Nhà xuất bản Trẻ');
INSERT INTO Publishers (PublisherID, PublisherName) VALUES (2, 'Nhà xuất bản Kim Đồng');
INSERT INTO Publishers (PublisherID, PublisherName) VALUES (3, 'Nhà xuất bản Văn học');
-- Thêm dữ liệu vào bảng Books
INSERT INTO Books (BookID, Title, AuthorID, PublisherID, PublishedYear, Quantity) VALUES (1, 'Cho tôi xin một vé đi tuổi thơ', 1, 1, 2008, 10);
INSERT INTO Books (BookID, Title, AuthorID, PublisherID, PublishedYear, Quantity) VALUES (2, 'Dế Mèn phiêu lưu ký', 2, 2, 1941, 5);
INSERT INTO Books (BookID, Title, AuthorID, PublisherID, PublishedYear, Quantity) VALUES (3, 'Những ngọn nến trong đêm', 3, 3, 1997, 8);
-- Thêm dữ liệu vào bảng Readers
INSERT INTO Readers (ReaderID, Name, Class, DateOfBirth) VALUES (1, 'Nguyễn Văn A', '10A1', '2005-01-01');
INSERT INTO Readers (ReaderID, Name, Class, DateOfBirth) VALUES (2, 'Trần Thị B', '10A2', '2005-02-02');
INSERT INTO Readers (ReaderID, Name, Class, DateOfBirth) VALUES (3, 'Lê Văn C', '10A3', '2005-03-03');
-- Thêm dữ liệu vào bảng Borrow_Return
INSERT INTO Borrow_Return (TransactionID, BookID, ReaderID, BorrowDate, ReturnDate) VALUES (1, 1, 1, '2023-10-01', '2023-10-15');
INSERT INTO Borrow_Return (TransactionID, BookID, ReaderID, BorrowDate, ReturnDate) VALUES (2, 2, 2, '2023-10-02', '2023-10-16');
INSERT INTO Borrow_Return (TransactionID, BookID, ReaderID, BorrowDate, ReturnDate) VALUES (3, 3, 3, '2023-10-03', '2023-10-17');
```
Trên đây là thiết kế cơ sở dữ liệu cho hệ thống quản lý thư viện của trường học, bao gồm các bảng, sơ đồ quan hệ và các câu truy vấn SQL cần thiết. Nếu bạn cần thêm thông tin hoặc có câu hỏi khác, hãy cho tôi biết!