阳泉集团网站建设,有做美食的网站有哪些,详情页设计收费,最新备案域名问题描述#xff1a;
本题用到下面三个关系表#xff1a;
CARD 借书卡。 CNO 卡号#xff0c;NAME 姓名#xff0c;CLASS 班级
BOOKS 图书。 BNO 书号#xff0c;BNAME 书名,AUTHOR 作者#xff0c;PRICE 单价#xff0c;QUANTITY 库存册数
BORROW 借书记录。 CNO 借…问题描述
本题用到下面三个关系表
CARD 借书卡。 CNO 卡号NAME 姓名CLASS 班级
BOOKS 图书。 BNO 书号BNAME 书名,AUTHOR 作者PRICE 单价QUANTITY 库存册数
BORROW 借书记录。 CNO 借书卡号BNO 书号RDATE 还书日期
备注限定每人每种书只能借一本库存册数随借书、还书而改变。
要求实现如下15个处理
1. 写出建立BORROW表的SQL语句要求定义主码完整性约束和引用完整性约束
--实现代码
CREATE TABLE BORROW(CNO int FOREIGN KEY REFERENCES CARD(CNO),BNO int FOREIGN KEY REFERENCES BOOKS(BNO),RDATE datetime,PRIMARY KEY(CNO,BNO)) 2. 找出借书超过5本的读者,输出借书卡号及所借图书册数
--实现代码
SELECT CNO,借图书册数COUNT(*)
FROM BORROW
GROUP BY CNO
HAVING COUNT(*)53. 查询借阅了水浒一书的读者输出姓名及班级
--实现代码
SELECT * FROM CARD c
WHERE EXISTS(SELECT * FROM BORROW a,BOOKS b WHERE a.BNOb.BNOAND b.BNAMEN水浒AND a.CNOc.CNO) 4. 查询过期未还图书输出借阅者卡号、书号及还书日期
--实现代码
SELECT * FROM BORROW
WHERE RDATEGETDATE() 5. 查询书名包括网络关键词的图书输出书号、书名、作者
--实现代码
SELECT BNO,BNAME,AUTHOR FROM BOOKS
WHERE BNAME LIKE N%网络% 6. 查询现有图书中价格最高的图书输出书名及作者
--实现代码
SELECT BNO,BNAME,AUTHOR FROM BOOKS
WHERE PRICE(SELECT MAX(PRICE) FROM BOOKS) 7. 查询当前借了计算方法但没有借计算方法习题集的读者输出其借书卡号并按卡号降序排序输出
--实现代码
SELECT a.CNO
FROM BORROW a,BOOKS b
WHERE a.BNOb.BNO AND b.BNAMEN计算方法AND NOT EXISTS(SELECT * FROM BORROW aa,BOOKS bbWHERE aa.BNObb.BNOAND bb.BNAMEN计算方法习题集AND aa.CNOa.CNO)
ORDER BY a.CNO DESC 8. 将C01班同学所借图书的还期都延长一周
--实现代码
UPDATE b SET RDATEDATEADD(Day,7,b.RDATE)
FROM CARD a,BORROW b
WHERE a.CNOb.CNOAND a.CLASSNC01 9. 从BOOKS表中删除当前无人借阅的图书记录
--实现代码
DELETE A FROM BOOKS a
WHERE NOT EXISTS(SELECT * FROM BORROWWHERE BNOa.BNO) 10. 如果经常按书名查询图书信息请建立合适的索引
--实现代码
CREATE CLUSTERED INDEX IDX_BOOKS_BNAME ON BOOKS(BNAME)11. 在BORROW表上建立一个触发器完成如下功能如果读者借阅的书名是数据库技术及应用就将该读者的借阅记录保存在BORROW_SAVE表中注ORROW_SAVE表结构同BORROW表
--实现代码
CREATE TRIGGER TR_SAVE ON BORROW
FOR INSERT,UPDATE
AS
IF ROWCOUNT0
INSERT BORROW_SAVE SELECT i.*
FROM INSERTED i,BOOKS b
WHERE i.BNOb.BNOAND b.BNAMEN数据库技术及应用 12. 建立一个视图显示力01班学生的借书信息只要求显示姓名和书名
--实现代码
CREATE VIEW V_VIEW
AS
SELECT a.NAME,b.BNAME
FROM BORROW ab,CARD a,BOOKS b
WHERE ab.CNOa.CNOAND ab.BNOb.BNOAND a.CLASSN力0113. 查询当前同时借有计算方法和组合数学两本书的读者输出其借书卡号并按卡号升序排序输出
--实现代码
SELECT a.CNO
FROM BORROW a,BOOKS b
WHERE a.BNOb.BNOAND b.BNAME IN(N计算方法,N组合数学)
GROUP BY a.CNO
HAVING COUNT(*)2
ORDER BY a.CNO DESC 14. 假定在建BOOKS表时没有定义主码写出为BOOKS表追加定义主码的语句
--实现代码
ALTER TABLE BOOKS ADD PRIMARY KEY(BNO) 15.1 将NAME最大列宽增加到10个字符假定原为6个字符
--实现代码
ALTER TABLE CARD ALTER COLUMN NAME varchar(10) 15.2 为该表增加1列NAME系名可变长最大20个字符
--实现代码
ALTER TABLE CARD ADD 系名 varchar(20)