图书管理系统作业之SQL

来源:百度知道 编辑:UC知道 时间:2024/05/26 05:32:35
问题描述:
本题用到下面三个关系表:
CARD 借书卡。 CNO 卡号,NAME 姓名,CLASS 班级
BOOKS 图书。 BNO 书号,BNAME 书名,AUTHOR 作者,PRICE 单价,QUANTITY 库存册数
BORROW 借书记录。 CNO 借书卡号,BNO 书号,RDATE应还书日期
备注:限定每人每种书只能借一本;库存册数随借书、还书而改变。
要求实现如下15个处理:
1. 写出建立BORROW表的SQL语句,要求定义主码完整性约束和引用完整性约束。
2. 找出借书超过5本的读者,输出借书卡号及所借图书册数。
3. 查询借阅了"水浒"一书的读者,输出姓名及班级。
4. 查询过期未还图书,输出借阅者(卡号)、书号及还书日期。
5. 查询书名包括"网络"关键词的图书,输出书号、书名、作者。
6. 查询现有图书中价格最高的图书,输出书名及作者。
7. 查询当前借了"计算方法"但没有借"计算方法习题集"的读者,输出其借书卡号,并按卡号降序排序输出。
8. 将"C01"班同学所借图书的还期都延长一周。
9. 从BOOKS表中删除当前无人借阅的图书记录。
10.如果经常按书名查询图书信息,请建立合适的索引。
11.在BORROW表上建立一个触发器,完成如下功能:如果读者借阅的书名是"数据库技术及应用",就将该读者的借阅记录保存在BORROW_SAVE表中(注ORROW_SAVE表结构同BORROW表)。
12.建立一个视图,显示“力01”班学生的借书信息(只要求显示姓名和书名)。
Create view as

13.查询当前同时借有"计算方法"和"组合数学"两本书的读者,输出其借书卡号,并按卡号升序排序输出。
14.假定在建BOOKS表时没有定义主码,写出为BOOKS表追加定义主码的语句。

1 use SISO
create table BORROW
(
CNO int NOT NULL,
BNO int NOT NULL,
RDATE datetime
) GO

ALTER TABLE BORROW
ADD CONSTRAINT PK_CNO PRIMARY KEY(CNO) ALTER TABLE BORROW
ADD CONSTRAINT UQ_CNO UNIQUE KEY(CNO)
GO

2 select CNO as 借书卡号,count(*) as 所借图书册数
from BORROW
group by CNO
having count(*)>5

3 select NAME,CLASS from CARD a,BOOKS b,BORROW c
where a.CNO=c.CNO and b.BNO=c.BNO and b.BNAME=‘水浒’

4 select CNO,BNO,RDATE from BORROW
where RDATE<getdate() and RETRUN=0

5 select BNO,BNAME,AUTHOR