数据库存储过程实验代码

本文通过一系列实验代码展示了如何在数据库中创建、修改和执行存储过程,包括查询计算机系女生信息、处理输入参数、根据姓名查询年龄和选课信息,并探讨了临时表的使用,特别是全局和局部临时表的区别。
部署运行你感兴趣的模型镜像

实验代码如下:

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 

您可能感兴趣的与本文相关的镜像

Linly-Talker

Linly-Talker

AI应用

Linly-Talker是一款创新的数字人对话系统,它融合了最新的人工智能技术,包括大型语言模型(LLM)、自动语音识别(ASR)、文本到语音转换(TTS)和语音克隆技术

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值