数据库存储过程实验代码

实验代码如下:

use student
/*1.创建一个存储过程my_proc,查询“学生表”中所有计算机系女生的学号、姓名、性别、年龄和所在院系。*/
create procedure my_proc
as
select 学号,姓名,性别,年龄,所在院系 from 学生表 where 性别='女'and 所在院系='计算机'
return

/*(2)执行存储过程*/
exec my_proc

/*3.修改存储过程,使其能够查询计算机系女生的所有基本信息*/
alter procedure my_proc
as
select *  from 学生表 where 性别='女'and 所在院系='计算机'
return

exec my_proc
drop procedure my_proc

/*1 .带输入参数的存储过程
(1)创建一个存储过程my_procsex,使其能够查询“学生表”中男学生或女学生的学号、姓名、性别、年龄和所在院系
(2)执行存储过程*/
USE STUDENT
create procedure my_procsex
@sex char(2),
@sex2 char(2)
as
select 学号,姓名,性别,年龄,所在院系 from 学生表
where 性别=@sex or 性别=@sex2
return
drop procedure my_procsex
exec my_procsex @sex='男',@sex2='女'

/*创建一个存储过程my_procage,使其能够根据学生姓名,查询学生年龄。
(考虑当学生不存在时给出提示信息)*/
create procedure my_procage
@name char(20)
as
if not exists(
select 年龄 from  学生表 where  姓名=@name)
print '没有找到该学生信息'

return

exec my_procage @name='a'
drop procedure my_procage

/*1)创建一个存储过程my_procstatus,使其能够根据学生姓名,查询学生的选课信息。
(如果没有输入学生姓名,返回状态码55;如果输入的学生姓名不存在,则返回状态码-155)*/

drop procedure my_procstatus


create procedure my_procstatus
@name varchar(10)
as
if @name=''
return 55
select 成绩表.学号,课程号 from 成绩表,学生表 where
 成绩表.学号=学生表.学号 and 学生表.姓名=@name
if not exists(
select 成绩表.学号,课程号 from 成绩表,学生表 where
成绩表.学号=学生表.学号 and 学生表.姓名=@name
)
return -155
select 成绩表.学号,课程号 from 成绩表,学生表 where
 成绩表.学号=学生表.学号 and 学生表.姓名=@name

return

declare @status int
exec @status=my_procstatus @name=''
if @status=-155
print'没有找到'
if @status=55
print'没有输入名字'

/*在存储过程中使用临时表,不指定题目,请理解全局临时表与局部临时表的区别*/
create procedure my_procsave
as
select 姓名 from (select * from 学生表 where 所在院系='计算机')#A
where #A.性别='女'
return

exec my_procsave

drop procedure my_procsave
create procedure my_procsave
as
select 姓名 from (select * from 学生表 where 所在院系='计算机')##A
where ##A.性别='女'
return

exec my_procsave 

展开阅读全文

没有更多推荐了,返回首页