本文用3个题目,从建立数据库到创建存储过程,详细讲解数据库的功能。

题目1

        学校图书馆借书信息管理系统建立三个表:
        学生信息表:student

字段名称

数据类型

说明

stuID

char(10)

学生编号,主键

stuName

Varchar(10)

学生名称

major

Varchar(50)

专业

图书表:book

字段名称

数据类型

说明

stuID

char(10)

学生编号,主键

stuName

Varchar(10)

学生名称

major

Varchar(50)

专业

借书信息表:borrow

字段名称

数据类型

说明

borrowID

char(10)

借书编号,主键

stuID

char(10)

学生编号,外键

BID

char(10)

图书编号,外键

T_time

datetime

借书日期

B_time

datetime

还书日期

请编写SQL语句完成以下的功能:
1) 查询“计算机”专业学生在“2007-12-15”至“2008-1-8”时间段内借书的学生编号、学生名称、图书编号、图书名称、借出日期;参考查询结果如下图所示:

2) 查询所有借过图书的学生编号、学生名称、专业;参考查询结果如下图所示:
3) 查询借过作者为“安意如”的图书的学生姓名、图书名称、借出日期、归还日期;参考查询结果如下图所示:
4) 查询目前借书但未归还图书的学生名称及未还图书数量;参考查询结果如下图所示:
        附加:建表语句:
  1. USE master
    GO
    /* $建库 */
    --检验数据库是否存在,如果为真,删除此数据库--
    IF exists(SELECT * FROM sysdatabases WHERE name='BOOK')
    DROP DATABASE BOOK
    GO
    CREATE DATABASE BOOK
    GO --建数据表--
    USE BOOK
    GO
    CREATE TABLE student --学生信息表
    (
    stuID CHAR() primary key, --学生编号
    stuName CHAR() NOT NULL , --学生名称
    major CHAR() NOT NULL --专业
    )
    GO
    CREATE TABLE book --图书表
    (
    BID CHAR() primary key, --图书编号
    title CHAR() NOT NULL, --书名
    author CHAR() NOT NULL, --作者
    )
    GO
    CREATE TABLE borrow --借书表
    (
    borrowID CHAR() primary key, --借书编号
    stuID CHAR() foreign key(stuID) references student(stuID), --学生编号
    BID CHAR() foreign key(BID) references book(BID),--图书编号
    T_time datetime NOT NULL, --借出日期
    B_time datetime --归还日期
    )
    GO --学生信息表中插入数据--
    INSERT INTO student(stuID,stuName,major)VALUES('','林林','计算机')
    INSERT INTO student(stuID,stuName,major)VALUES('','白杨','计算机')
    INSERT INTO student(stuID,stuName,major)VALUES('','虎子','英语')
    INSERT INTO student(stuID,stuName,major)VALUES('','北漂的雪','工商管理')
    INSERT INTO student(stuID,stuName,major)VALUES('','五月','数学')
    --图书信息表中插入数据--
    INSERT INTO book(BID,title,author)VALUES('B001','人生若只如初见','安意如')
    INSERT INTO book(BID,title,author)VALUES('B002','入学那天遇见你','晴空')
    INSERT INTO book(BID,title,author)VALUES('B003','感谢折磨你的人','如娜')
    INSERT INTO book(BID,title,author)VALUES('B004','我不是教你诈','刘庸')
    INSERT INTO book(BID,title,author)VALUES('B005','英语四级','白雪')
    --借书信息表中插入数据--
    INSERT INTO borrow(borrowID,stuID,BID,T_time,B_time)VALUES('T001','','B001','2007-12-26',null)
    INSERT INTO borrow(borrowID,stuID,BID,T_time,B_time)VALUES('T002','','B003','2008-1-5',null)
    INSERT INTO borrow(borrowID,stuID,BID,T_time,B_time)VALUES('T003','','B001','2007-10-8','2007-12-25')
    INSERT INTO borrow(borrowID,stuID,BID,T_time,B_time)VALUES('T004','','B002','2007-12-16','2008-1-7')
    INSERT INTO borrow(borrowID,stuID,BID,T_time,B_time)VALUES('T005','','B004','2007-12-22',null)
    INSERT INTO borrow(borrowID,stuID,BID,T_time,B_time)VALUES('T006','','B005','2008-1-6',null)
    INSERT INTO borrow(borrowID,stuID,BID,T_time,B_time)VALUES('T007','','B001','2007-9-11',null)
    INSERT INTO borrow(borrowID,stuID,BID,T_time,B_time)VALUES('T008','','B004','2007-12-10',null)
    INSERT INTO borrow(borrowID,stuID,BID,T_time,B_time)VALUES('T009','','B005','2007-10-16','2007-12-18')
    INSERT INTO borrow(borrowID,stuID,BID,T_time,B_time)VALUES('T010','','B002','2007-9-15','2008-1-5')
    INSERT INTO borrow(borrowID,stuID,BID,T_time,B_time)VALUES('T011','','B003','2007-12-28',null)
    INSERT INTO borrow(borrowID,stuID,BID,T_time,B_time)VALUES('T012','','B003','2007-12-30',null)

标准答案:

-- 1)查询“计算机”专业学生在“2007-12-15”至“2008-1-8”时间段内借书的学生编号、学生名称、图书编号、图书名称、借出日期—

  1. select 学生编号=stuID,学生名称=(select stuName from student where stuID=borrow.stuID),图书编号=BID,图书名称=(select title from book where BID=borrow.BID),借出日期=T_time from borrow where stuID in (select stuID from student where major='计算机') and T_time>'2007-12-15' and T_time<'2008-1-8'  

-- 2)查询所有借过图书的学生编号、学生名称、专业--

  1. select 学生编号=stuID,学生名称=stuName,专业=major from student where stuID in (select stuID from borrow)  

-- 3)查询借过作者为“安意如”的图书的学生姓名、图书名称、借出日期--

  1. select 学生名称=(select stuName from student where stuID=borrow.stuID),图书名称=(select title from book where BID=borrow.BID),借出日期=T_time,归还日期=B_time from borrow where BID in (select BID from book where author='安意如') 

-- 4)查询目前借书但未归还图书的学生名称及未还图书数量--

  1. select 学生名称=(select stuName from student where stuID=borrow.stuID),借书数量=count(*) from borrow where B_time is null group by stuID  

题目2

        程序员工资表:ProWage

字段名称

数据类型

说明

ID

int

自动编号,主键

PName

Char(10)

程序员姓名

Wage

int

工资

创建一个存储过程,对程序员的工资进行分析,月薪1500到10000不等,如果有百分之五十的人薪水不到2000元,给所有人加薪,每次加100,再进行分析,直到有一半以上的人大于2000元为止,存储过程执行完后,最终加了多少钱?

        例如:如果有百分之五十的人薪水不到2000,给所有人加薪,每次加100元,直到有一半以上的人工资大于2000元,调用存储过程后的结果如图:
        请编写T-SQL来实现如下功能:
1) 创建存储过程,查询是否有一半程序员的工资在2200、3000、3500、4000、5000或6000元之上,如果不到分别每次给每个程序员加薪100元,至之一半程序员的工资达到2200,3000,3500,4000,5000或6000元。
2) 创建存储过程,查询程序员平均工资在4500元,如果不到则每个程序员每次加200元,至到所有程序员平均工资达到4500元。
        建表语句:
    USE master
GO
/* $建库 */
--检验数据库是否存在,如果为真,删除此数据库--
IF exists(SELECT * FROM sysdatabases WHERE name='Wage')
DROP DATABASE Wage
GO
CREATE DATABASE Wage
GO --建数据表--
USE Wage
GO
CREATE TABLE ProWage --程序员工资表
(
ID int identity(,) primary key, --工资编号
PName CHAR() NOT NULL , --程序员姓名
Wage int NOT NULL --工资
)
GO
--插入数据--
INSERT INTO ProWage(PName,Wage)VALUES('青鸟',)
INSERT INTO ProWage(PName,Wage)VALUES('张三',)
INSERT INTO ProWage(PName,Wage)VALUES('李四',)
INSERT INTO ProWage(PName,Wage)VALUES('二月',)
INSERT INTO ProWage(PName,Wage)VALUES('蓝天',)

标准答案:

  1. --1、创建存储过程--

题目3

        学生成绩信息三个表,结构如下: 
        学生表:Member

字段名称

数据类型

说明

MID

Char(10)

学生号,主键

MName

Char(50)

姓名

课程表:F

字段名称

数据类型

说明

FID

Char(10)

课程,主键

FName

Char(50)

课程名

成绩表:Score

字段名称

数据类型

说明

SID

int

自动编号,主键,成绩记录号

FID

Char(10)

课程号,外键

MID

Char(10)

学生号,外键

Score

int

成绩

请编写T-SQL语句来实现如下功能:
1) 查询各个学生语文、数学、英语、历史课程成绩,例如下表:

姓名

语文

数学

英语

历史

张萨

78

67

89

76

王强

89

67

84

96

李三

70

87

92

56

李四

80

78

97

66

2) 查询四门课中成绩低于70分的学生及相对应课程名和成绩。
3) 统计各个学生参加考试课程的平均分,且按平均分数由高到底排序。
4) 创建存储过程,分别查询参加1、2、3、4门考试及没有参加考试的学生名单,要求显示姓名、学号。

        建表语句:
    USE master
GO
/* $建库 */
--检验数据库是否存在,如果为真,删除此数据库--
IF exists(SELECT * FROM sysdatabases WHERE name='Student')
DROP DATABASE Student
GO
CREATE DATABASE Student
GO --建数据表--
USE Student
GO
CREATE TABLE Member --学生表
(
MID char() primary key, --学生号
MName CHAR() NOT NULL --姓名
)
GO
CREATE TABLE F --课程表
(
FID char() primary key, --课程号
FName CHAR() NOT NULL --课程名
)
GO
CREATE TABLE score --学生成绩表
(
SID int identity(,) primary key, --成绩记录号
FID char() foreign key(FID) references F(FID) , --课程号
MID char() foreign key(MID) references Member(MID) , --学生号
Score int NOT NULL --成绩
)
GO
--课程表中插入数据--
INSERT INTO F(FID,FName)VALUES('F001','语文')
INSERT INTO F(FID,FName)VALUES('F002','数学')
INSERT INTO F(FID,FName)VALUES('F003','英语')
INSERT INTO F(FID,FName)VALUES('F004','历史')
--学生表中插入数据--
INSERT INTO Member(MID,MName)VALUES('M001','张萨')
INSERT INTO Member(MID,MName)VALUES('M002','王强')
INSERT INTO Member(MID,MName)VALUES('M003','李三')
INSERT INTO Member(MID,MName)VALUES('M004','李四')
INSERT INTO Member(MID,MName)VALUES('M005','阳阳')
INSERT INTO Member(MID,MName)VALUES('M006','虎子')
INSERT INTO Member(MID,MName)VALUES('M007','夏雪')
INSERT INTO Member(MID,MName)VALUES('M008','璐璐')
INSERT INTO Member(MID,MName)VALUES('M009','珊珊')
INSERT INTO Member(MID,MName)VALUES('M010','香奈儿')
--成绩表中插入数据--
INSERT INTO Score(FID,MID,Score)VALUES('F001','M001',)
INSERT INTO Score(FID,MID,Score)VALUES('F002','M001',)
INSERT INTO Score(FID,MID,Score)VALUES('F003','M001',)
INSERT INTO Score(FID,MID,Score)VALUES('F004','M001',)
INSERT INTO Score(FID,MID,Score)VALUES('F001','M002',)
INSERT INTO Score(FID,MID,Score)VALUES('F002','M002',)
INSERT INTO Score(FID,MID,Score)VALUES('F003','M002',)
INSERT INTO Score(FID,MID,Score)VALUES('F004','M002',)
INSERT INTO Score(FID,MID,Score)VALUES('F001','M003',)
INSERT INTO Score(FID,MID,Score)VALUES('F002','M003',)
INSERT INTO Score(FID,MID,Score)VALUES('F003','M003',)
INSERT INTO Score(FID,MID,Score)VALUES('F004','M003',)
INSERT INTO Score(FID,MID,Score)VALUES('F001','M004',)
INSERT INTO Score(FID,MID,Score)VALUES('F002','M004',)
INSERT INTO Score(FID,MID,Score)VALUES('F003','M004',)
INSERT INTO Score(FID,MID,Score)VALUES('F004','M004',)
INSERT INTO Score(FID,MID,Score)VALUES('F001','M006',)
INSERT INTO Score(FID,MID,Score)VALUES('F002','M006',)
INSERT INTO Score(FID,MID,Score)VALUES('F003','M006',)
INSERT INTO Score(FID,MID,Score)VALUES('F004','M006',)
INSERT INTO Score(FID,MID,Score)VALUES('F002','M007',)
INSERT INTO Score(FID,MID,Score)VALUES('F003','M008',)
INSERT INTO Score(FID,MID,Score)VALUES('F004','M007',)
INSERT INTO Score(FID,MID,Score)VALUES('F004','M009',)
INSERT INTO Score(FID,MID,Score)VALUES('F002','M009',)

标准答案:

-- 1)查询各个学生语文、数学、英语、历史课程成绩--

    SELECT Member.MName AS 姓名,
英语 = SUM(CASE F.FName WHEN '语文' THEN Score.Score END),
数学 = SUM(CASE F.FName WHEN '数学' THEN Score.Score END),
语文 = SUM(CASE F.FName WHEN '英语' THEN Score.Score END),
历史 = SUM(CASE F.FName WHEN '历史' THEN Score.Score END)
FROM Score, Member,F
WHERE F.FID = Score.FID AND Member.MID =Score.MID GROUP BY Member.MName

-- 2)查询四门课中成绩低于70分的学生及相对应课程名和成绩--

  1. select 姓名=(select MName from Member where MID=Score.MID),课程名=(select FName from F where FID=Score.FID),成绩=Score from Score where Score<  

-- 3)统计各个学生四课程的平均分,且按平均分数由高到底排序--

  1. select 姓名=(select MName from Member where MID=Score.MID),平均分=Avg(Score) from Score group by MID order by 平均分 desc  

-- 4)创建存储过程--

if exists (select * from sysobjects where name='P_stu')
drop procedure P_stu
GO
create procedure P_stu
@num int
As
print'参加'+convert(varchar(),@num)+'门课考试的学生姓名及学号:'
select 姓名=(select MName from Member where MID=Score.MID),学号=MID from Score group by MID having count(*)=@num --调用存储过程--
exec P_stu @num=

转:http://blog.csdn.net/crazygolf/article/details/38989461

SQL存储过程实例详解的更多相关文章

  1. 9.SQL存储过程实例详解

    本文用3个题目,从建立数据库到创建存储过程,详细讲解数据库的功能. 题目1 学校图书馆借书信息管理系统建立三个表:学生信息表:student 字段名称 数据类型 说明 stuID char(10) 学 ...

  2. Mysql 存储过程实例详解

    存储过程和函数是事先经过编译并存储在数据库中的一段SQL语句的集合,存储和和函数的区别在于函数必须有返回值,而存储过程没有,存储过程的参数可以使用IN.OUT.INOUT类型,而函数的参数只能是IN类 ...

  3. sql注入实例详解(二)

    前言 这篇文章就是一个最基本的SQl手工注入的过程了.基本上在sqlilabs上面的实验,如果知道了其中的全部知识点,都可以通过以下的步骤进行脱裤.下面的这个步骤也是其他的脱裤手段的基础.如果想要精通 ...

  4. mysql触发器trigger 实例详解

    mysql触发器trigger 实例详解 (转自 https://www.cnblogs.com/phpper/p/7587031.html)   MySQL好像从5.0.2版本就开始支持触发器的功能 ...

  5. ORACLE中RECORD、VARRAY、TABLE、IS REF CURSOR 的使用及实例详解

    ORACLE中RECORD.VARRAY.TAB.IS REF CURSOR LE的使用及实例详解 create or replaceprocedure PRO_RECORD_ROW_TAB_EXAM ...

  6. 【SQL Server】SQL触发器经验详解

    [SQL Server]SQL触发器经验详解 | 浏览: 4314 | 更新: 2013-01-07 15:33 25 11 全文阅读分步阅读   加入杂志 步骤 1 2 3 4 5 6 7 8   ...

  7. Java程序员从笨鸟到菜鸟之(一百)sql注入攻击详解(一)sql注入原理详解

    前段时间,在很多博客和微博中暴漏出了12306铁道部网站的一些漏洞,作为这么大的一个项目,要说有漏洞也不是没可能,但其漏洞确是一些菜鸟级程序员才会犯的错误.其实sql注入漏洞就是一个.作为一个菜鸟小程 ...

  8. Entity Framework实例详解

    Entity Framework Code First的默认行为是使用一系列约定将POCO类映射到表.然而,有时候,不能也不想遵循这些约定,那就需要重写它们.重写默认约定有两种方式:Data Anno ...

  9. 转:【工欲善其事必先利其器】—Entity Framework实例详解

    开始本篇文章之前,先说一下Entity Framework 6 Alpha1在NuGet中已可用,原文链接http://blogs.msdn.com/b/adonet/archive/2012/10/ ...

随机推荐

  1. perl学习之:理解贪婪匹配和最小匹配之间的区别

    正则表达式的新手经常将贪婪匹配和最小匹配理解错误.默认情况下,Perl 的正则表达式是“贪婪地”,也就是说它们将尽可能多地匹配字符. 下面的脚本打印出“matched defgabcdef”,因为它尽 ...

  2. python插件,pycharm基本用法,markdown文本编写,jupyter notebook的基本操作汇总

    5.14自我总结 一.python插件插件相关技巧汇总 安装在cmd上运行 #比如安装 安装:wxpy模块(支持 Python 3.4-3.+ 以及 2.7 版本):pip3 install wxpy ...

  3. sweetalert使用随笔

    删除前确认框: //找到删除那天记录的按钮,触发点击事件 $(".del").on('click', function () { swal({ title: "操作确认& ...

  4. H.264编码profile & level控制

    背景知识 先科普一下profile&level.(这里讨论最常用的H264) H.264有四种画质级别,分别是baseline, extended, main, high:  1.Baseli ...

  5. Vector模板类----构造与析构

    /* 基于C++平台*/ typedef int rank; //用int来定义 “秩” 这种概念 #define DEFAULT_CAPACIITY 3 //默认初始容量,实际应用中可以取更大的值 ...

  6. python第三方库之openpyxl(1)

    python第三方库之openpyxl(1) 简介 Openpyxl是一个用于读写Excel 2010 xlsx/xlsm/xltx/xltm文件的Python库,其功能非常强大.Excel表格可以理 ...

  7. IIS中如何应用程序启用https协议

    首先已经安装完了SSL证书 1.找到需要添加的站点,右击 ---> 编辑绑定-->添加--->选择  ""https"-->选择"SSL ...

  8. nginx的报错500

    500:服务器内部错误,也就是服务器遇到意外情况,而无法履行请求. 500错误一般有几种情况: 1. web脚本错误,如php语法错误,lua语法错误等. 2. 访问量大的时候,由于系统资源限制,而不 ...

  9. HackerRank# Hexagonal Grid

    原题地址 铺瓷砖的变种,做法也是类似 假设地板长下面这样,灰色的是无法填充的空洞,初始时可以把N块之外的地板填充成灰色的,便于边界处理 假设现在从后向前已经处理完了一部分,绿色的砖块代表已经遍历过了, ...

  10. getParameter 与 getAttribute的区别

    request.getAttribute():是request时设置的变量的值,用request.setAttribute("name","您自己的值");来设 ...