本文是在Cat Qi的原贴的基础之上,经本人逐题分别在MySql数据库中实现的笔记.

参考原贴:http://www.cnblogs.com/qixuejia/p/3637735.html

01 问题描述

本题用到下面三个关系表:

借书卡:card

cno name class
卡号 姓名 班级

图书:books

bno bname author price quantity
书号 书名 作者 单价 库存册数

借书记录:borrow

cno bno rdate
借书卡号 书号 还书日期

备注:限定每人每种书只能借一本;库存册数随借书、还书而改变。

02 问题及SQL实现

1、写出建立card,books,borrow表的SQL语句,要求定义表borrow的主码完整性约束和引用完整性约束

 drop table if exists books;
create table books (
bno int(11) auto_increment ,
bname varchar(30) default null,
author varchar(30) default null,
price float(6,2) default null,
quantity int(11) default null,
primary key (bno)
) engine=innodb default charset=utf8; drop table if exists card;
create table card (
cno int(11) auto_increment,
name varchar(30) default null,
class varchar(30) default null,
primary key (cno)
) engine=innodb default charset=utf8; drop table if exists borrow;
create table borrow (
cno int(11) not null,
bno int(11) not null,
rdate datetime null default current_timestamp,
primary key (cno,bno),
key bno (bno),
constraint bno foreign key (bno) references books (bno),
constraint cno foreign key (cno) references card (cno)
) engine=innodb default charset=utf8;

插入测试数据:

 insert into card(name,class) values('张三','计科一班');
insert into card(name,class) values('李四','计科一班');
insert into card(name,class) values('王五','计科二班');
insert into card(name,class) values('六四','计科二班');
insert into card(name,class) values('七七','软工一班');
insert into card(name,class) values('粑粑','软工二班'); insert into books(bname,author,price,quantity) values ('水浒','施耐庵',188,3);
insert into books(bname,author,price,quantity) values ('计算机网络','谢希仁',49,3);
insert into books(bname,author,price,quantity) values ('计算方法','严蔚敏',58,3);
insert into books(bname,author,price,quantity) values ('计算方法习题集','殷人昆',188,3);
insert into books(bname,author,price,quantity) values ('数据库技术及应用','王珊',38,3);
insert into books(bname,author,price,quantity) values ('组合数学','周伟',28,3);
insert into books(bname,author,price,quantity) values ('redis初探','周成龙',25,3); insert into borrow(cno,bno) values(1,1);
insert into borrow(cno,bno) values(2,1);
insert into borrow(cno,bno) values(3,1);
insert into borrow(cno,bno) values(4,3);
insert into borrow(cno,bno) values(4,6);
insert into borrow(cno,bno) values(5,6);
insert into borrow(cno,bno) values(2,7);

2、找出借书多于1本的读者,输出借书卡号及所借图书册数

select cno as "卡号",count(*) as "借书册数"
from borrow
group by cno
having count(cno)>1;

3、查询借阅了"水浒"一书的读者,输出姓名及班级

select c.name as "姓名",c.class as "班级"
from card c
where c.cno in
(
select br.cno from borrow br join books bs
on br.bno = bs.bno and bs.bname="水浒"
);

4、查询过期未还图书,输出借阅者(卡号)、书号及还书日期

select cno as "卡号",bno as "书号",rdate as "还书日期"
from borrow
where rdate< now();

5、查询书名包括"网络"关键词的图书,输出书号、书名、作者

select bno,bname,author from books where bname like "%网络%";

6、查询现有图书中价格最高的图书,输出书名及作者

select bname,author
from books
where price = (select max(price) from books);

7、查询当前借了"计算方法"但没有借"计算方法习题集"的读者,输出其借书卡号,并按卡号降序排序输出

select bo.cno
from borrow bo, books
where bo.bno = books.bno and books.bname ="计算方法" and not exists
(
select * from borrow r,books b where r.bno = b.bno and b.bname="计算方法习题集"
)
order by bo.cno desc;

8、将"计科一班"班同学所借图书的还期都延长一周

update borrow set rdate=adddate(rdate,INTERVAL 7 day)
where cno in (select cno from card where class="计科一班");

9、从books表中删除当前无人借阅的图书记录

delete from books where bno not in
(select distinct bno from borrow );

这里有3本图书被删除,只剩下1、3、6、7,执行删除操作后重新插入books表的原始数据以便做后面的题目。

10、如果经常按书名查询图书信息,请建立合适的索引

create index idx_books_name on books(bname);
--关于索引的使用参考:
--https://zhidao.baidu.com/question/492877300.html

11、在borrow表上建立一个触发器,完成如下功能:如果读者借阅的书名是"数据库技术及应用",就将该读者的借阅记录保存在borrow_save表中(注borrow_save表结构同borrow表)

create view v_borrow
as
select c.name,b.bname
from card c,books b,borrow r
where c.cno=r.cno and b.bno=r.bno and c.class="计科一班";

12、查询当前同时借有"计算方法"和"组合数学"两本书的读者,输出其借书卡号,并按卡号升序排序输出

select b.cno
from borrow b
where b.bno in (select bno from books where bname in ("计算方法","组合数学"))
group by b.cno
having count(b.bno)=2
order by b.cno ;

13、假定在建books表时没有定义主键,写出为books表追加定义主键的语句

alter table books add primary key (bno);

14、为card表增加1列deptname(系名),可变长,最大50个字符 

alter table card add deptname varchar(50);

THE END.

SQL面试笔试经典题(Part 2)的更多相关文章

  1. SQL面试笔试经典题(Part 1)

    本文是在Cat Qi的原贴的基础之上,经本人逐题分别在MySql数据库中实现的笔记,持续更新... 参考原贴:http://www.cnblogs.com/qixuejia/p/3637735.htm ...

  2. JAVA面试/笔试经典题

    1.short s1 = 1; s1 = s1 + 1;有什么错? short s1 = 1; s1 += 1;有什么错? 对于short s1 = 1; s1 = s1 + 1; 由于s1+1运算时 ...

  3. 《PHP面试笔试真题库》——PHP面试的好帮手

    你好,是我琉忆. 一个文艺的PHP开发工程师. 很荣幸能够在这里带来我的第一本新书--<PHP程序员面试笔试真题库>. 一.创作过程 <PHP 程序员面试笔试真题库>是我的第三 ...

  4. 《PHP程序员面试笔试真题解析》——新书上线

    你好,是我--琉忆.很高兴可以跟你分享我的新书. 很高兴,在出版了PHP程序员面试笔试宝典后迎来了我的第二本书出版--<PHP程序员面试笔试真题解析>. 如果你是一个热爱PHP的程序员,刚 ...

  5. BAT面试笔试33题:JavaList、Java Map等经典面试题!答案汇总!

    JavaList面试题汇总 1.List集合:ArrayList.LinkedList.Vector等. 2.Vector是List接口下线程安全的集合. 3.List是有序的. 4.ArrayLis ...

  6. unity,C#,游戏面试笔试真题

    最开始的两家公司笔试面试题目 一家公司是学校聘请研究教育方面VR课件的公司,面试没几天,就收到了面试通过的消息,后面因为通过了另一家游戏公司而拒绝了. 另一家公司是一家游戏外企,在春熙路,当时笔试还可 ...

  7. sql练习题及经典题

    https://blog.csdn.net/mrbcy/article/details/68965271 经典例题 19.查询选修“3-105”课程的成绩高于“109”号同学成绩的所有同学的记录. S ...

  8. 面试&笔试常见题,你了解多少?

    HTML:1.  什么是语义化的HTML?有何意义?为什么要做到语义化?(高频率考题)2.  行内元素和块元素分别有哪些?(高频率)3.  严格模式与混杂模式的区分?如何触发这两种模式?(高频率)4. ...

  9. 搜狗面试的经典题(C++map按值排序,class struct的差别)

    一:起因 (1)java  Map排序(key,value).请看还有一篇博客 java Map排序 (2)c++ map排序(key,value),能够对c++ map和java Map进行对照:之 ...

随机推荐

  1. 快消品迎来B2B元年,行业将如何变革?

    一年接近尾声,又到了年终总结的时候,宴会厅里传来各种激情澎湃的演讲,有的行业遍地开花.欢声笑语不绝于耳:有的行业却没能迎来"昨夜东风",只能嗟叹"不堪回首".2 ...

  2. jquery判断当前浏览器的实现代码

    写了一个判断当前浏览器类型及版本的方法,只在IE 8/11 .谷歌 .360 浏览器(不完全)上测试过,需要用到jquery 核心代码: ;(function($, window, document, ...

  3. python网络爬虫 新浪博客篇

    上次写了一个爬世纪佳缘的爬虫之后,今天再接再厉又写了一个新浪博客的爬虫.写完之后,我想了一会儿,要不要在博客园里面写个帖子记录一下,因为我觉得这份代码的含金量确实太低,有点炒冷饭的嫌疑,就是把上次的代 ...

  4. python实现网络爬虫下载天涯论坛帖子

    最近发现天涯论坛是一个挺有意思的网站,有各种乱七八糟的帖子足以填补无聊时候的空虚感,但是相当不爽的一件事就是天涯的分页模式下想连贯的把楼主的内容看完实在是太心酸了,一个999页的帖子,百分之九十都是无 ...

  5. 从零开始编写自己的C#框架(16)——Web层后端父类

    本章节讲述的各个类是后端系统的核心之一,涉及到系统安全验证.操作日志记录.页面与按键权限控制.后端页面功能封装等内容,希望学习本系列的朋友认真查看新增的类与函数,这对以后使用本框架进行开发时非常重要. ...

  6. 《你不知道的JavaScript》整理(二)——this

    最近在读一本进阶的JavaScript的书<你不知道的JavaScript(上卷)>,这次研究了一下“this”. 当一个函数被调用时,会创建一个活动记录(执行上下文). 这个记录会包含函 ...

  7. 在iOS中实现一个简单的画板App

    在这个随笔中,我们要为iPhone实现一个简单的画板App. 首先需要指出的是,这个demo中使用QuarzCore进行绘画,而不是OpenGL.这两个都可以实现类似的功能,区别是OpenGL更快,但 ...

  8. 前端开发之走进Vue.js

    Vue.js作为目前最热门最具前景的前端框架之一,其提供了一种帮助我们快速构建并开发前端项目的新的思维模式.本文旨在帮助大家认识Vue.js,了解Vue.js的开发流程,并进一步理解如何通过Vue.j ...

  9. AC自动机-算法详解

    What's Aho-Corasick automaton? 一种多模式串匹配算法,该算法在1975年产生于贝尔实验室,是著名的多模式匹配算法之一. 简单的说,KMP用来在一篇文章中匹配一个模式串:但 ...

  10. React Native环境搭建以及几个基础控件的使用

    之前写了几篇博客,但是没有从最基础的开始写,现在想了想感觉不太合适,所以现在把基础的一些东西给补上,也算是我从零开始学习RN的经验吧! 一.环境搭建 首先声明一下,本人现在用的编辑器是SublimeT ...