MySQL是一種非常強大的關系型數據庫,被廣泛應用于各種應用程序中。在許多應用程序中,可能需要用到圖書表、讀者表和借閱表。這三個表之間存在著復雜的關聯,因此需要合理地設計表結構,方便程序的開發和查詢等操作。
首先是圖書表。圖書表主要存儲圖書的相關信息,例如書名、作者、出版社、出版時間、ISBN號、分類等。我們可以設計一個名為books的表,表結構如下(pre): CREATE TABLE `books` ( `id` int(11) NOT NULL AUTO_INCREMENT, `title` varchar(255) NOT NULL, `author` varchar(255) NOT NULL, `publisher` varchar(255) NOT NULL, `publish_time` date NOT NULL, `isbn` varchar(13) NOT NULL, `category` varchar(50) NOT NULL, PRIMARY KEY (`id`), UNIQUE KEY `isbn` (`isbn`) ) ENGINE=InnoDB AUTO_INCREMENT=1 DEFAULT CHARSET=utf8; (/pre)其中,id為自增主鍵,title、author、publisher、isbn等為圖書的基本信息,isbn需要保證唯一性,方便查詢。
接下來是讀者表。讀者表主要存儲讀者的基本信息,例如姓名、性別、出生日期、電話、郵箱等。我們可以設計一個名為readers的表,表結構如下(pre): CREATE TABLE `readers` ( `id` int(11) NOT NULL AUTO_INCREMENT, `name` varchar(255) NOT NULL, `gender` varchar(10) NOT NULL DEFAULT 'unknown', `birthdate` date NOT NULL, `tel` varchar(20) NOT NULL, `email` varchar(255) NOT NULL, PRIMARY KEY (`id`), UNIQUE KEY `tel` (`tel`), UNIQUE KEY `email` (`email`) ) ENGINE=InnoDB AUTO_INCREMENT=1 DEFAULT CHARSET=utf8; (/pre)其中,id為自增主鍵,name、gender、birthdate等為讀者的基本信息,tel、email需要保證唯一性,方便查詢。
最后是借閱表。借閱表主要記錄讀者借閱圖書的相關信息,例如讀者id、圖書id、借閱時間、歸還時間等。我們可以設計一個名為borrows的表,表結構如下(pre): CREATE TABLE `borrows` ( `reader_id` int(11) NOT NULL, `book_id` int(11) NOT NULL, `borrow_time` date NOT NULL, `return_time` date DEFAULT NULL, PRIMARY KEY (`reader_id`,`book_id`), KEY `book_id` (`book_id`), CONSTRAINT `borrows_book_id_fk` FOREIGN KEY (`book_id`) REFERENCES `books` (`id`) ON UPDATE CASCADE, CONSTRAINT `borrows_reader_id_fk` FOREIGN KEY (`reader_id`) REFERENCES `readers` (`id`) ON UPDATE CASCADE ) ENGINE=InnoDB DEFAULT CHARSET=utf8; (/pre)其中,reader_id和book_id是外鍵,分別關聯到讀者表和圖書表中的id字段。借閱時間borrow_time是必需的,而歸還時間return_time是可選的。PRIMARY KEY定義了reader_id和book_id作為主鍵,保證了借閱關系的唯一性。兩個FOREIGN KEY分別定義了外鍵關系,ON UPDATE CASCADE表示在更新主表的主鍵時,同時更新外鍵引用該主鍵的記錄。