《图书管理系统综合习题(共6页).doc》由会员分享,可在线阅读,更多相关《图书管理系统综合习题(共6页).doc(6页珍藏版)》请在taowenge.com淘文阁网|工程机械CAD图纸|机械工程制图|CAD装配图下载|SolidWorks_CaTia_CAD_UG_PROE_设计图分享下载上搜索。
1、精选优质文档-倾情为你奉上图书管理系统1 需求说明(分用户分解各项功能)图书管理系统包括图书管理,学生借阅图书管理两大功能,具体的业务功能为:l 管理员进行新书入库l 管理员对图书基本信息进行修改l 管理员记录学生的借书信息和还书信息l 管理员对图书基本信息进行查询l 管理员对图书的借出还入情况进行查询l 管理员对学生的借书还书信息进行查询l 管理员对学生的基本信息进行查询2 数据库设计2.2 实体属性分析由图1所示的E-R模型转换成的关系模式如下:l 读者(借书证号,姓名,性别,年龄,住址),借书证号设为主键;l 图书(图书编号,图书名,图书作者,图书价格,图书类别,出版日期,出版社),图书
2、编号设为主键; 2.1 数据库概念模型设计(E-R模型)经过分析,一个学生可以借阅多本图书,一本图书也可以被多个系统包含的实体有学生和图书,两个实体之间通过借阅发生联系,联系的类型为多对多。其对应的E-R模型如图1所示。mn借书时间图书借阅读者还书时间图1 系统E-R模型2.3 数据库逻辑模型设计根据数据库逻辑结构设计结果,在SQL Server2005数据库管理系统中,创建Library数据库,并在该数据库中创建3张数据表,分别为学生表student、图书表book、借阅表borrow,表结构如表1至表3所示。表1 读者表reader字段名数据类型长度约束备注 ReaderIdchar12主
3、键借书证号 SnameVarchar10非空姓名 SsexChar2默认值为“男”性别SbirthdayDatetime出生日期 SaddressVarchar50住址表2 图书表book字段名数据类型长度约束备注BnoVarchar20主键图书编号BnameVarchar20非空图书名BauthorVarchar20图书作者Bpricetinyint图书价格BcategoryVarchar20图书类别BpressdayDatetime出版日期BpressVarchar20出版社表3 借阅表borrow字段名数据类型长度与格式约束备注BnoVarchar20主键,外键图书编号ReaderIdc
4、har12主键,外键学号BorrowdayDatetime主键借书时间ReturndayDatetime还书时间确认转换生成的3个关系模式都符合第三范式。3 SQL语句练习1. 写出创建学生表student、借阅表borrow的SQL语句。2. 查询每个学生的基本信息,按学号升序排序。3. 查询每个学生的借阅情况(学号、姓名、书号、借书日期、还书日期),包括没有借书的学生的借阅情况。4. 查询每本图书被借阅的情况,包括没有被借阅的图书情况。5. 查询同名的图书。6. 查询借阅过“高等教育出版社”出版的图书的学生信息。7. 查询没有借过书的学生信息。8. 查询图书的总册数、最高价、最低价、总价值
5、和平均价。9. 查询定价在30到40元之间的图书信息。10. 查询书名以“数据库”起始的图书信息。11. 统计各出版社图书的数量。12. 统计每本书的借阅次数。13. 查询每本书的基本信息,按价格降序排序。14. 统计每个学生的借书数量。(包括已经还的书和正在借的书)15. 将“人民邮电出版社”出版的图书的价格减少3元。16. 删除没有人借阅的图书信息。17. 删除图书“数据库基础及应用”的借阅信息。18. 创建一个视图,查询每个男生的借阅情况(学号,书号,借书日期,还书日期)。然后使用该视图,统计每个男生的借书数量。(包括已经还的书和正在借的书)1. 写出创建读者表reader、图书表boo
6、k、借阅表borrow的SQL语句。CREATE TABLE student ( ReaderId char (12) PRIMARY KEY, Sname varchar (10) NOT NULL, Ssex char (2) default 男, Sbirthday datetime, Saddress varchar (50)CREATE TABLE book ( Bno varchar(20) PRIMARY KEY, Bname varchar(20) NOT NULL, Bauthor varchar(20), Bprice tinyint, Bcategory varchar(
7、10), Bpressday datetime, Bpress varchar(10) CREATE TABLE borrow ( Bno varchar(20), ReaderId char(12), Borrowday datetime, Returnday datetime, PRIMARY KEY (Bno,ReaderId,Borrowday), FOREIGN KEY (Bno ) REFERENCES book(Bno ), FOREIGN KEY (ReaderId) REFERENCES student(ReaderId)2. 查询每个学生的基本信息,按学号升序排序。sele
8、ct * from studentorder by ReaderId3. 查询每个学生的借阅情况(学号、姓名、书号、借书日期、还书日期),包括没有借书的学生信息。select s.ReaderId,sname,bno,borrowday,returndayfrom student s left join borrow on s.ReaderId=borrow.ReaderId4. 查询每本图书被借阅的情况,包括没有被借阅的图书情况。select * from book b left join borrow on b.bno=borrow.bno5. 查询同名的图书。select distinc
9、t b1.bno,b1.bname from book b1 join book b2 on b1.name=b2.name6. 查询借阅过“高等教育出版社”出版的图书的学生信息。select * from student s join on borrow on s.ReaderId=borrow.ReaderId join on book b on b.bno=borrow.bnowhere bpress=高等教育出版社7. 查询没有借过书的学生信息。select * from studentwhere ReaderId not in(select distinct ReaderId fro
10、m borrow)8. 查询图书的总册数、最高价、最低价、总价值和平均价。select count(bno),max(bprice),min(bprice),sum(bprice),avg(bprice)from book9. 查询定价在30到40元之间的图书信息。select * from bookwhere bprice between 30 and 4010. 查询书名以“数据库”起始的图书信息。select * from bookwhere bname like 数据库%11. 统计各出版社图书的数量。select count(bno)from bookgroup by bpress1
11、2. 统计每本书的借阅次数。select count(bno)from borrowgroup by bno13. 查询每本书的基本信息,按价格降序排序。select * from bookorder by bprice desc14. 统计每个学生的借书数量。(包括已经还的书和正在借的书)select count(ReaderId)from borrowgroup by ReaderId15. 将“人民邮电出版社”出版的图书的价格减少3元。update bookset bprice=bprice-3where bpress=人民邮电出版社16. 删除没有人借阅的图书信息。delete fro
12、m book where bno not in(select distinct bno from borrow)17. 删除书名为“数据库基础及应用”的图书信息。delete from bookwhere bname=数据库基础及应用18. 创建一个视图,查询每个男生的借阅情况(学号,书号,借书日期,还书日期)。然后使用该视图,统计每个男生的借书数量。(包括已经还的书和正在借的书)create view v1asselect borrow.ReaderId,bno,borrowday,returnday from borrow join student s on borrow.ReaderId=s.ReaderIdwhere ssex=男select count(ReaderId)from v1group by ReaderId专心-专注-专业