SQL 存储过程(学生,课程表,选修表)

一.存储过程的分类 在SQL Server中存储过程分过两类:

1)系统存储过程("sp_"作为前缀)

2)用户自定义存储过程

二.创建和执行存储过程

1)创建在存储过程的方法一般有两种:

1.使用SQL Server Management Studio

2.使用T—SQL语句(重点)

2)T—SQL中常用的控制流关键字

begin...end(定义语句块);break(退出最内层的while循环);continue(重新开始while循环); goto label;if...else;return;waitfor(为语句的

执行设置延迟);while(当特定条件为true时重复语句)

3)实例:使用T-SQL语句创建和执行存储过程的方法

--3.1 创建名为"Stuproc1"的存储过程,用来查询班级为"计算机应用"的学生的学号,姓名和性别
create proc Stuproc1
as
select 学号,姓名,性别
from 学生
where 学生.班级='计算机应用' exec Stuproc1
--备注:as 用于指定该存储过程要执行的操作 --3.2 创建存储过程"Stuproc2",根据用户输入的班级名,查询该班学生的学号,姓名和性别.若不输入班级名,则显示"计算机应用"班的学生
create proc Stuproc2
@班级 char(20)='计算机应用'
as
select 学生.学号,学生.姓名,学生.性别
from 学生
where 学生.班级=@班级 exec Stuproc2 @班级='计算机网络' --3.3 创建存储过程Stuproc3,根据用户输入的学号和课程名,返回该课程的成绩
create proc Stuproc3
(@学号 char(9),@课程名 char(20))
as
select 选修.成绩
from 课程 inner join 选修 on 选修.课程号=课程.课程号
where 选修.学号=@学号 and 课程.课程名=@课程名 exec Stuproc3 @学号='1002',@课程名='计算机软件' --3.4 创建存储过程Stuproc4,根据用户输入的课程名,返回选修该课程的学生人数
create proc Stuproc4
@课程名 char(20)
as
select 课程名,COUNT(*) as 学生人数
from 课程 inner join 选修 on 课程.课程号=选修.课程号
group by 课程名 exec Stuproc4 @课程名='计算机应用' drop proc Stuproc4 --3.5 创建存储过程Stuproc5,用于查询不及格课程数在4门以上(不包含4门)的学生的全部信息.将这些学生信息存入退学表
create table 退学(
学号 char(9) primary key,
姓名 nvarchar(5),
班级 char(20),
性别 nchar(1),
出生年月日 smalldatetime,
电话 char(11),
Email varchar(30),
备注 varchar(100)
)
create proc Stuproc5
as
insert into 退学
select*
from 学生
where 学号 in(select 学号
from 选修
where 成绩<60
group by 学号
having COUNT (*) >4
)
drop proc Stuproc5 exec Stuproc5
select * from 退学 --3.6 某些同学因为个人志向,入学后向学校提出转班级申请.创建存储过程Stuproc6,根据输入的学生学号,修改该同学的班级名称
create proc Stuproc6
(@学号 char(10),@班级 char(20))
as
update 学生
set 班级=@班级
where 学号=@学号 exec Stuproc6 @学号='1001',@班级='计算机导论'
select *
from 学生

三.查看存储过程

--用于显示存储过程的所有者,创建时间,存储过程的参数及其数据类型

sp_help

--用于显示存储过程的源代码

sp_helptext [存储过程名称]

例:

sp_helptext Stuproc5

--用于显示和存储过程相关的数据库对象

sp_depends

--用于返回当前数据库中的存储过程列表

sp_stored_procedures

例:

exec Stuproc5

四.修改存储过程

--把存储过程Stuproc1修改为能查询"计算机应用班"学生的全部信息
alter proc Stuproc1
as
select *
from 学生
where 班级='计算机应用' sp_helptext Stuproc1 exec Stuproc1

五.重命名存储过程

--把存储过程"Stuproc1"重命名为"计算机网络学生"
sp_rename Stuproc1,计算机网络学生
sp_help

六.册除存储过程

--要删除存储过程"Stuproc2"
drop proc Stuproc2

SQL 存储过程(学生,课程表,选修表)的更多相关文章

  1. SQL 触发器(学生,课程表,选修表)

    SQL 触发器(学生,课程表,选修表) 触发器是一种特殊类型的存储过程,它不由用户通过命令来执行,而是在用户对表执行了插入,删除或修改表中数据等操作时激活执行.可以这样形容:存储过程像一个遥控炸弹,我 ...

  2. 一个SQL存储过程面试题(比较简单)

    三个月前刚毕业的时候,听到存储过程就头疼. 写一个SQL存储过程,建立一个表USER 字段是姓名,年龄,职位,权限,然后向里面插入6条数据,然后查询出年龄大于18的所有信息. 下面是答案: 复制代码 ...

  3. 学生表 课程表 成绩表 教师表 50个常用sql语句

    原文:http://www.cnblogs.com/zengxiangzhan/archive/2009/09/23/1572276.html Student(S#,Sname,Sage,Ssex) ...

  4. 数据库 简单查询 Sql Server 学生表 课程表 选课表

    创建教材中的三张表格,并输入相应的数据 Create table student( Sno char(9), Same char(20), Ssex char(2), Sage smallint, S ...

  5. 数据库SQL语句中 查询选修了全部课程的学生的学号和姓名

    一.SQL语言查询选修了全部课程的学生的学号和姓名. 两种解决途径: 第一种: 我们可以表示为在SC表中某个学生选修的课程数等于C表中课程总数.相应的SQL语言如下: select S#,SNAME ...

  6. sql-hive笔试题整理 1 (学生表-成绩表-课程表-教师表)

    题记:一直在写各种sql查询语句,最长的有一百多行,自信什么需求都可以接,可......,想了想,可能一直在固定的场景下写,平时也是以满足实际需求为目的,竟不知道应试的题都是怎么出的,又应该怎么做.遂 ...

  7. SQL Server利用RowNumber()内置函数与Over关键字实现通用分页存储过程(支持单表或多表结查集分页)

    SQL Server利用RowNumber()内置函数与Over关键字实现通用分页存储过程,支持单表或多表结查集分页,存储过程如下: /******************/ --Author:梦在旅 ...

  8. Sql中判断"数据库"、"表"、"临时表"、"存储过程"和列"是否存在

    --判断数据库是否存在 IF EXISTS (SELECT * FROM MASTER..sysdatabases WHERE NAME = '库名')    PRINT 'exists ' else ...

  9. SQL Server 删除数据库所有表和所有存储过程

    场景: SQL Server中,需要删除所有表或所有存储过程时,手动的方式只能逐个进行删除,耗个人时间,所以想弄个语句来实现这样的需求.   如果由于外键约束删除table失败,则先删除所有约束: - ...

随机推荐

  1. python 包管理工具pip安装与使用

    pip是python的一个包管理工具,与之类似的工具还有easy_install.根据官网的说法 如果你的python版本在Python 2 >=2.7.9 or Python 3 >=3 ...

  2. P78、面试题10:二进制中1的个数

    题目:请实现一个函数,输入一个整数,输出该数二进制表示中1的个数.例如把9表示成二进制1001,有2位是1.因此如果输入9,该函数输出2. 相关题目: 1)用一条语句判断一个整数是不是2的整数次方.一 ...

  3. WCF实例上下文

    实例上下文模式(IntanceContext Mode)表示服务端的服务实例与客户端的服务代理的绑定方式. 在WCF中有三种不同的实例上下文模式,单调(Per-Call)模式,会话(Per-Sessi ...

  4. VS2005下开发PPC2003和WM50编译器一些设置

    1.vs2005开发WM5时,编译器和linker的选项配合问题 链接:http://www.mivi.name/blog/index_en.php?itemid=258 首先说ARM4 ARM4T ...

  5. ListView中使用type需要注意的东西 java.lang.ArrayIndexOutOfBoundsException: length=2; index=2 addScrapView

    ListView中使用type需要注意的东西 在使用ListView时,如果使用了getItemViewType, 记得他的值一定要是从0开始计数的. 且要覆盖getViewTypeCount方法.并 ...

  6. 大四实习准备4_java内部类

    2015-4-30 [昨天又可耻地休息了一天,懒劲比较大啊.跟懒劲有直接关系,这几天对幸福的感知也黯淡了,对未来的幸福不是那么渴望了.表现在对亲情和爱情上. 我想生活的本意是积极进取.茁壮生长并时常感 ...

  7. poj3692

    首先这道题很容易想到二分图相关(给的很明确了): 但是我们发现,男孩之间都互相认识,女孩之间也互相认识 这样是不能划分点集的 但是男孩之间都互相认识,女孩之间也互相认识,所以男孩和男孩,女孩和女孩之间 ...

  8. poj2828

    很容易想到一种动态的做法:平衡树…… 或者是二分+树状数组 但,前者编程复杂度较大,而且据说会被卡(没试过):后者理论上超时(据说可以擦边过?): 所以要尝试新的算法: 倒着考虑,显然最后一个对象的位 ...

  9. mssql查找备注(text,ntext)类型字段为空的方法

    在sql语句中,如果查找某个文本字段值为空的,可以用select * from 表 where 字段='' ,但是如果这个字段数据类型是text或者ntext,那上面的sql语句就要出错了. 解决办法 ...

  10. C#中的预处理器指令

    C#中有许多名为“预处理器指令”的命令.这些命令从来不会转化为可执行代码中的命令,但会影响编译过程的各个方面. 例如,使用预处理器指令可以禁止编译器编译代码的某一部分.如果计划发布两个版本的代码,即基 ...