使用SQL语句创建存储过程

在这里插入图片描述

前言:

本篇文章是记录学校学习SQL server中知识,可用于复习资料.

目录

  • 前言:
  • 一、存储过程的创建
    • 1、创建简单存储过程
    • 2、创建带参数的存储过程
    • 3、创建带输出参数的存储过程
  • 二 、使用T一SQL语句管理和维护存储过程
    • 2.1 使用sp_helptext查看存储过程student_sc的定义脚本
    • 2.2 使用select语句查看student_sc存储过程的定义脚本(提示:通过查询表sysobjects和表
    • 2.3 修改存储过程
    • 2.4 删除存储过程

一、存储过程的创建

定义:

存储过程是为了完成特定功能的SQL语句集合,存储在数据库中,用户通过指定存储过程的名称并给出参数来执行。

优点:
1、方便修改。
  因为存储过程是存储在数据库中的,如果需要涉及到修改SQL语句,那么数据库专业人员只需要去修改数据库中的存储过程就可以,对程序毫无影响,如果用SQL语句的话,SQL语句是写在程序中的,如果涉及到修改SQL语句,那么就需要去修改源程序。

2、存储过程比SQL语句执行更快速:

  存储过程是为了完成特定功能的SQL语句的集合,如果为了完成某一功能,使用了大量的SQL语句,那么执行存储过程只执行一次就可以,而SQL语句呢,则是需要执行多个。就类似于c语言中的自定义函数,甚至比自定义函数还要灵活很多.

1、创建简单存储过程

(1)创建一个名为stu_pr存储过程,该存储过程能查询出o51班学生的所有资料,包括学生的基本信息、学生的选课信息(含未选课同学的信息)。要求在创建存储过程前请判断该存储过程是否已创建,若已创建则先删除,并给出“已删除! p信息,否则就给出“不存在,可创建! ”的信息。

先进行判断是否存在:

if exists (select * from sysobjects where name='stu_pr' and type='P')begin
drop procedure stu_pr print '已删除! '
end
else
print '不存在,可创建! '

执行结果:

创建语句:

create procedure stu_pr
as
select distinct * from student s
left join sc on s.sno=sc.sno
left join course c on c.Cno=sc.Cno where classno='051'

使用刚刚创建的存储过程:

exec stu_pr

执行结果:
在这里插入图片描述

2、创建带参数的存储过程

(1)创建一个名为stu_proc1存储过程,查询某系、某姓名的学生的学号、姓名、年龄,选修课程名、成绩。系名和姓名在调用该存储过程时输入,其默认值分别为“%”与"林%”。执行该存储过程,用多种参数加以测试。

if exists (select * from sysobjects where name='stu_proc1' and type='P')
begin
drop procedure stu_proc1 print '已册删除!'
end
else
print '不存在,可创建! '

执行结果:
在这里插入图片描述
创建语句:

create procedure stu_proc1
@sdept varchar(10)='%', @sname varchar(10)='林%'
as
select Sname , s.Sno, YEAR(getdate ( ) ) -YEAR(Birth) Age, Cname ,Grade from student 		s, Course c,sc
where s.Sno=sc.sno and c.Cno=sc.Cno
and s.Sname like @sname and s.sdept like @sdept

执行结果:
在这里插入图片描述
执行已经创建好的存储过程

执行1:

exec stu_proc1

在这里插入图片描述
执行2:

exec stu_proc1 @sdept='%', @sname ='林%'

执行结果:

在这里插入图片描述
(2)创建一个名为Student_sc存储过程,可查询出某段学号的同学的学号、姓名、总成绩。(学号起始号与终止号在调用时输入,可设默认值)。执行该存储过程

if exists (select name from sysobjects where name='student_sc' and type='P')drop procedure student_sc 
go
create procedure student_sc@sno_begin varchar (10)='20110001 ',@sno_end varchar (10)='20110103' 
asselect s.Sno,Sname , SUM (grade) total_grade from student s,scwhere s.sno=sc.sno and s.sno between @sno_begin and @sno_endgroup by s.sno ,sname

执行:

exec student_sc

3、创建带输出参数的存储过程

(1)创建一个名为Course_sum存储过程,可查询某门课程考试的总成绩。总成绩可以输出,以便进一步调用。

if exists (select name from sysobjects where name='Course_sum' and type='P ')
drop procedure course_sum

在这里插入图片描述

创建:

create procedure course_sum @cname varchar(10)='告'
as
select SUM(grade) total_grade , COUNT(sno)sno from course c, sc
where c.Cno=sc.Cno and Cname like cname
执行:
exec course_sum '高数'

在这里插入图片描述
(2)创建一执行该存储过程的批处理,要求当总成绩小于100时,显示信息为:“XXX课程的总.成绩为:XX,其总分未达100分”。超过100时,显示信息为。“XX课程的总成绩为:XX”。

create procedure sum_grade2
@cname varchar (10) , @@sum smallint output
as
select @@sum=sum ( grade)from course c , sc
where c.Cno=sc.Cno and Cname like cname

创建:

declare @@sumgrade smallint
exec sum_grade2 '高数',@@sumgrade output if @@sumgrade<100
begin
print '高数的总成绩为:'+CAST(@@sumgrade as varchar(20))+',其总分未达到分。'
end
else
print '高数的总成绩为:'+CAST(@@sumgrade As varchar (20))+'。'

在这里插入图片描述
创建:

create procedure update_sc
@cno varchar(10),@sno varchar (10) , @grade int with recompile,encryption--重编译,加密
as
update sc
set grade=@grade
where sc.cno=@cno and sc.sno=@sno
exec update_sc '001','20110001','80'

二 、使用T一SQL语句管理和维护存储过程

2.1 使用sp_helptext查看存储过程student_sc的定义脚本

语句:

sp_helptext student_sc

在这里插入图片描述

2.2 使用select语句查看student_sc存储过程的定义脚本(提示:通过查询表sysobjects和表

语句:

syscomments)
select o.id, c.text
from sysobjects o inner join syscomments c
on o.id = c.id
where o.type = 'p' and o.name = 'student_sc'

在这里插入图片描述

2.3 修改存储过程

存储过程stu_pr改为查询学号为2011001的学生的详细资料。

alter procedure stu_pr
@sno varchar (10)
as
select distinct * from student 
where sno='20110001'

执行:

exec stu_pr @sno=2011001

2.4 删除存储过程

drop procedure stu_pr

6、使用sQL Server Management Studi管理存储过程
(1)在SQL Server Management Studio中重新创建刚删除的存储过程stu_pr
选择数据库student_info→可编程性→存储过程,右击“存储过程”→新建存储过程
在这里插入图片描述

(2)查看存储过程`stu_pr`,并将该过程修改为查询051班女生的所有资料。可编程性→存储过程→>stu _pr,右击stu _pr→>修改.

在这里插入图片描述

(3) 修改sQL语句,使之能查询051班所有女生的资料的存储过程
在这里插入图片描述
(3)删除存储过程stu_pr
选择存储过程stu _pr,右击,选择“删除”

在这里插入图片描述

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.hqwc.cn/news/8342.html

如若内容造成侵权/违法违规/事实不符,请联系编程知识网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

大禹智库:下一代向量数据库————具备在线化,协作化,可视化,自动化和安全互信的向量数据库

目录 一、在线化 二、协作化 三、可视化 四、自动化 五、安全互信 结论&#xff1a; 行业分析报告&#xff1a;下一代向量数据库的特征 摘要&#xff1a; 向量数据库是一种用于存储和处理向量数据的数据库系统。随着人工智能和大数据技术的快速发展&#xff0c;向量数据…

匹马赛跑,1个赛道,每次5匹进行比赛,无法对每次比赛计时,但知道每次比赛结果的先后顺序,最少赛多少次可以找出前三名?

1.实现 答&#xff1a;至少需要比7次。 25匹马随机分成5组&#xff0c;每组比赛一次也即总共比5次先看一下每组马的快慢情况。 我们一开始并不知道这25匹马中谁快谁慢&#xff0c;所以需要筛选出那些跑的较快的马出来去竞争前三名&#xff0c;只能将25匹马随机进行分组比赛&…

二叉树 — 给定二叉树中某个节点,返回该节点的后继节点

后继节点定义&#xff1a; 二叉树以中序的方式进行遍历打印&#xff0c;节点X的下一个节点&#xff0c;就是X的后继节点。 假设二叉树如下图所示&#xff1a;则中序遍历的后打印出来的就是 4 -> 2 -> 5 -> 1 -> 6 -> 3 -> 7。如果X 3&#xff0c;则X的后继节…

直接在Notepad++中运行GO语言-(通过NppExec插件)

前提条件&#xff1a; 1.建议阅读文章【直接在Notepad中运行GO语言】&#xff1a; 直接在Notepad中运行GO语言_go语言 notepad_西晋的no1的博客-CSDN博客 2.建议阅读文章【notepad 中安装NppExec插件】&#xff1a; notepad 中安装NppExec插件_西晋的no1的博客-CSDN博客 以下…

EasyCVR如何在不修改分辨率的情况下进行H.265自动转码H.264?

EasyCVR视频融合平台基于云边端一体化架构&#xff0c;可支持多协议、多类型设备接入&#xff0c;在视频能力上&#xff0c;平台可实现视频直播、录像、回放、检索、云存储、告警上报、语音对讲、电子地图、集群、H.265转码、智能分析以及平台级联等。 我们在此前的文章中介绍过…

微服务框架

流量入口Nginx 在上图中可以看到&#xff0c;Nginx作为整个架构的流量入口&#xff0c;可以理解为一个外部的网关&#xff0c;它承担着请求的路由转发、负载均衡、动静分离等功能。作为一个核心入口点&#xff0c;Nginx肯定要采用多节点部署&#xff0c;同时通过keepalived来实…

Spring 是什么框架?

对于一门技术&#xff0c;我们需要从为什么要学、学什么以及怎么学这三个方向入手来学习。那在说Spring这三点之前&#xff0c;我们先看Spring之前要学什么。 Java基础、Java语法进阶、MySQL基础操作、MySQL数据库设计和多表操作、JDBC、Maven基础、MyBatis、HMLCSS、JavaScrip…

ESP8266 RTOS SDK开发 windows开发

https://blog.csdn.net/qq_36347513/article/details/105066905 文件下载路径 https://docs.espressif.com/projects/esp8266-rtos-sdk/en/latest/get-started/windows-setup.html 下载编译环境MSYS2 下载完成后解压到根目录 双击mingw32.exe打开&#xff0c;ls看一下是在什么…

图书推荐管理系统Python,基于Django和协同过滤算法等实现

一、介绍 图书推荐系统 / 图书管理系统&#xff0c;以Python作为开发语言&#xff0c;基于Django实现&#xff0c;使用协同过滤算法实现对登录用户的图书推荐。 二、效果展示 三、演示视频 视频代码&#xff1a;https://www.yuque.com/ziwu/yygu3z/gq555ph49m9fvrze 四、Dj…

89C52RC普中单片机

1.静态数码管显示 数组函数 #include<regx52.h> void Delay(unsigned int xms);//带参延时函数ms /*静态数码管 P0&#xff1a;表示数码管的abcdefg dp P2.234表示位选 P21110 0011是第0号数码管 */ unsigned char NixieTable[]{0x3f,0x06,0x5b,0x4f,0x66,0x6d,0x7d,0x0…

安卓热修系列-插件资源冲突解决方案

作者&#xff1a;37手游移动客户端团队 背景 在做插件化过程中&#xff0c;宿主需要用到插件的资源&#xff0c;涉及到加载插件的资源&#xff1b; 因为插件是以apk的方式存在的&#xff0c;所以插件的ID和宿主的ID可能导致重复&#xff1b; 为了解决这个问题&#xff0c;需…

【云原生】Docker部署/容器加速器(最新版)

目录 初时Docker和部署 1.什么是Docker 2.容器和虚拟化的区别 3.部署Docker 1.卸载历史版本 2.设置存储库 3.安装Docker最新引擎 4.安装Docker特定安装引擎 1.先查看当前docker-ce都有那些版本 2.替换为所需版本&#xff0c;然后运行以下命令 要安装的命令&#xff1a; 5.启动D…