云题海 - 专业文章范例文档资料分享平台

当前位置:首页 > SQL存储过程实例(练习和答案)

SQL存储过程实例(练习和答案)

  • 62 次阅读
  • 3 次下载
  • 2025/5/23 2:39:55

T_time>'2007-12-15' and T_time<'2008-1-8' -- 2)查询所有借过图书的学生编号、学生名称、专业-- select 学生编号=stuID,学生名称=stuName,专业=major from student where stuID in (select stuID from borrow) -- 3)查询借过作者为“安意如”的图书的学生姓名、图书名称、借出日期-- 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)查询目前借书但未归还图书的学生名称及未还图书数量-- select 学生名称=(select stuName from student where stuID=borrow.stuID),借书数量=count(*) from borrow where B_time is null group by stuID

题目2

程序员工资表:ProWage

字段名称 ID PName Wage int Char(10) 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(1,1) primary key, --工资编号 PName CHAR(10) NOT NULL , --程序员姓名 Wage int NOT NULL --工资 ) GO --插入数据-- INSERT INTO ProWage(PName,Wage)VALUES('来棱',1900) INSERT INTO ProWage(PName,Wage)VALUES('张三',1200) INSERT INTO ProWage(PName,Wage)VALUES('李四',1800) INSERT INTO ProWage(PName,Wage)VALUES('二月',3500) INSERT INTO ProWage(PName,Wage)VALUES('蓝天',2780) 标准答案:

--1、创建存储过程-- if exists (select * from sysobjects where name='Sum_wage') drop procedure Sum_wage GO create procedure Sum_wage @PWage int, @AWage int, @total int as while (1=1) begin if (select count(*) from ProWage)>2*(select count(*) from ProWage where Wage>=@PWage) update ProWage set @total=@total+@AWage,Wage=Wage+@AWage else break end print'一共加薪:'+convert(varchar,@total)+'元' print'加薪后的程序员工资列表:' select * from ProWage --调用存储过程1-- exec Sum_wage @PWage=2000,@AWage=100,@total=0 exec Sum_wage @PWage=2200,@AWage=100,@total=0 exec Sum_wage @PWage=3000,@AWage=100,@total=0 exec Sum_wage @PWage=4000,@AWage=100,@total=0 exec Sum_wage @PWage=5000,@AWage=100,@total=0 exec Sum_wage @PWage=6000,@AWage=100,@total=0 --2、创建存储过程2-- if exists (select * from sysobjects where name='Avg_wage') drop procedure Avg_wage GO create procedure Avg_wage @PWage int, @AWage int, @total int as while (1=1) begin if ((select Avg(Wage) from ProWage)<=@PWage) update ProWage set @total=@total+@AWage,Wage=Wage+@AWage else break end print'一共加薪:'+convert(varchar,@total)+'元' print'加薪后的程序员工资列表:' select * from ProWage --调用存储过程-- exec Avg_wage @PWage=3000,@AWage=200,@total=0 exec Avg_wage @PWage=4500,@AWage=200,@total=0

题目3:

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

字段名称 MID MName 课程表:

字段名称 FID FName 成绩表:Score

字段名称 SID FID MID Score int Char(10) Char(10) int 数据类型 说明 自动编号,主键,成绩记录号 课程号,外键 学生号,外键 成绩 数据类型 Char(10) Char(50) 课程,主键 课程名 说明 数据类型 Char(10) Char(50) 说明 学生号,主键 姓名 请编写T-SQL语句来实现如下功能:

1) 查询各个学生语文、数学、英语、历史课程成绩,例如下表:

姓名 张萨 王强 李三 李四 语文 78 89 70 80 数学 67 67 87 78 英语 89 84 92 97 历史 76 96 56 66 2) 查询四门课中成绩低于70分的学生及相对应课程名和成绩。 3) 统计各个学生参加考试课程的平均分,且按平均分数由高到底排序。

4) 创建存储过程,分别查询参加1、2、3、4门考试及没有参加考试的学生名单,要求显

示姓名、学号。 建表语句:

搜索更多关于: SQL存储过程实例(练习和答案) 的文档
  • 收藏
  • 违规举报
  • 版权认领
下载文档10.00 元 加入VIP免费下载
推荐下载
本文作者:...

共分享92篇相关文档

文档简介:

T_time>'2007-12-15' and T_time<'2008-1-8' -- 2)查询所有借过图书的学生编号、学生名称、专业-- select 学生编号=stuID,学生名称=stuName,专业=major from student where stuID in (select stuID from borrow) -- 3)查询借过作者为“安意如”的图书的学生姓名、图书名称、借出日期-- 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 wh

× 游客快捷下载通道(下载后可以自由复制和排版)
单篇付费下载
限时特价:10 元/份 原价:20元
VIP包月下载
特价:29 元/月 原价:99元
低至 0.3 元/份 每月下载150
全站内容免费自由复制
VIP包月下载
特价:29 元/月 原价:99元
低至 0.3 元/份 每月下载150
全站内容免费自由复制
注:下载文档有可能“只有目录或者内容不全”等情况,请下载之前注意辨别,如果您已付费且无法下载或内容有问题,请联系我们协助你处理。
微信:fanwen365 QQ:370150219
Copyright © 云题海 All Rights Reserved. 苏ICP备16052595号-3 网站地图 客服QQ:370150219 邮箱:370150219@qq.com