【基础6】存储过程的 创建与调用

news2025/1/2 2:41:37

目录

什么是存储过程

用户自定义存储过程

练习


什么是存储过程

  1. 什么是存储过程

    • 类似于C语言中的函数。
    • 用来执行管理任务或应用复杂的业务规则
    • 存储过程可以带参数,也可以返回结果
    • 存储过程可以包含数据操纵等语句、变量、逻辑控制语句等。(单个select语句、select语句块、select语句与逻辑控制语句)
  2. 存储过程的优点

    • 执行速度更快
    • 允许模块化程序设计
    • 提高系统安全性
    • 减少网络流量
  3. 存储过程的分类

    1. 系统存储过程
      • 由系统定义,存放在master数据库中。
      • 类似c语言中的系统函数
      • 系统存储过程的名称都以“SP_ ”开头或“XP_ ”开头
    2. 用户自定义存储过程
      • 由用户在自己的数据库中创建的存储过程
      • 类似C语言中的用户自定义函数
  4. 常用的系统存储过程:XP_cmdshell

    --系统存储过程
    exec xp_cmdshell 'mkdir D:\bank' ,no_output    --加上no_output  只提示命令已完成,不显示 几行受影响,也不显示执行结果
    exec xp_cmdshell 'dir D:\bank'					--查看文件信息
    
    exec sp_helpdb Sales							--查看数据库信息 
    exec sp_databases								--查看当前服务器的所有数据库
    
    use Sales
    go
    exec sp_help Employees						--查看Employees表的所有  信息
    exec sp_helpconstraint Employees		--查看Employees表的所有  约束
    exec sp_helpindex Employees				--查看Employees表的所有  索引
    
    exec sp_helptext V_number		 			--显示未加密的存储过程
    
    exec sp_stored_procedures					--列出当前库中的所有存储过程
    
    
    

     

    • 可以执行dos命令下的一些操作

    • 以文本方式返回任何输出

    • 调用语法:

      exec xp _ cmdshell DOS命令[no_output]
      
    • 在sql 2005中启用扩展存储过程:xp_cmdshell

      要在外围配置管理器中启用

    • 在sql 2008及以上中启用扩展存储过程:xp_cmdshell

      --启用xp_cmdshell
      USE master 
      EXEC sp_configure 'show advanced options', 1 
      RECONFIGURE WITH OVERRIDE 
      EXEC sp_configure 'xp_cmdshell', 1 
      RECONFIGURE WITH OVERRIDE 
      EXEC sp_configure   'show advanced options', 0
      RECONFIGURE WITH OVERRIDE 
      
      
      --关闭xp_cmdshell
      USE master 
      EXEC sp_configure 'show advanced options', 1 
      RECONFIGURE WITH OVERRIDE 
      EXEC sp_configure 'xp_cmdshell', 0 
      RECONFIGURE WITH OVERRIDE 
      EXEC sp_configure   'show advanced options', 0
      RECONFIGURE WITH OVERRIDE 
      
      

用户自定义存储过程

  1. 用户自定义存储过程

    定义存储过程的语法

    create proc[edure] 存储过程名
    	@参数1 数据类型
    	@参数2 数据类型=默认值				 --有默认值的话才有(=默认值 ),这个是带默认值的输入参数。
    	@参数3 数据类型=默认值 output 	 --默认值后面有output的,这个是带默认值的输出参数
    	········
    	@参数n 数据类型=默认值 output 
    	as  
    	 SQL语句					--可以是学过的任何语句
    go
    
    

    无参存储过程的创建,调用存储过程 对存储过程的加密,显示创建存储过程的文本

       --创建存储过程:proc_销售额    ,查看每个人的销售情况
       --这个存储过程是显示所有人的销售额,不需要传参数,所以创建的是无参的存储过程
       use Sales
       go
       
       select * from Employees
       select * from Goods
       select * from Sell
       
       if exists (select * from sysobjects where name='proc_销售额')							--视图、表、存储过程 都是存储过程,全部的数据库对象:sysobjects
       drop procedure proc_销售额
       go
       create procedure proc_销售额
       as									--因为是没有参数,所以as前面不用写参数
       print '各员工的销售情况如下:'
       select 编号,姓名,销售额=case
       										when sum(G.零售价*S.数量) is null then '无销售信息'
       										else  cast(sum(G.零售价*S.数量) as char(20))
       									end 
       from Employees E left join Sell S on E.编号=S.售货员工编号 left join Goods G on G.商品编号=S.商品编号 group by E.编号,E.姓名
    
    --调用存储过程 execute 简写:exec 
    --在创建存储过程的过程中,已经编译过一次,以后再也不需要进行编译,直接调用就可以
    --语法:exec 过程名 [参数]		--有参数的话加参数,没有就不用。  
    exec proc_销售额
    
    --查看存储过程创建的文本
    exec sp_helptext proc_销售额
    
    --修改存储过程文本 为加密
    --1、
    		if exists (select * from sysobjects where name='proc_销售额')							--视图、表、存储过程 都是存储过程,全部的数据库对象:sysobjects
    		drop procedure proc_销售额
    		go
    		create procedure proc_销售额
    		--在这里加一个   with encryption
    		with encryption --加密存储过程创建的文本
    		as									--因为是没有参数,所以as前面不用写参数
    		print '各员工的销售情况如下:'
    		select 编号,姓名,销售额=case
    												when sum(G.零售价*S.数量) is null then '无销售信息'
    												else  cast(sum(G.零售价*S.数量) as char(20))
    											end 
    		from Employees E left join Sell S on E.编号=S.售货员工编号 left join Goods G on G.商品编号=S.商品编号 group by E.编号,E.姓名
    
    
    --2、取消对文本的加密,创建存储过程的文本中,create  改成  alter  然后把加密的那行文本注释/删除
    alter procedure proc_销售额
    --with encryption --加密存储过程创建的文本
    as									--因为是没有参数,所以as前面不用写参数
    print '各员工的销售情况如下:'
    select 编号,姓名,销售额=case
    										when sum(G.零售价*S.数量) is null then '无销售信息'
    										else  cast(sum(G.零售价*S.数量) as char(20))
    									end 
    from Employees E left join Sell S on E.编号=S.售货员工编号 left join Goods G on G.商品编号=S.商品编号 group by E.编号,E.姓名
    
    
  2. 输入过程的参数分为两种:

    • 输入参数:往里面传值,
    • 输出参数 :调用完成后,传出一个结果值,这个值可以进一步使用

    输入参数存储过程的创建 /调用/多个参数有默认值的调用

    --输入参数的存储过程
    if exists (select * from sysobjects where name='proc_销售额')					
    drop procedure proc_销售额
    go
    create procedure proc_销售额
    @EmployeesID int
    as						
    set nocount on		
    print '编号为'+cast(@EmployeesID as char(4))+'的员工销售情况如下:'
    select 编号,姓名,销售额=case
    										when sum(G.零售价*S.数量) is null then '无销售信息'
    										else  cast(sum(G.零售价*S.数量) as char(20))
    									end 
    from Employees E left join Sell S on E.编号=S.售货员工编号 left join Goods G on G.商品编号=S.商品编号 where 编号=@EmployeesID
    group by E.编号,E.姓名
    go
    
    --调用输入参数的存储过程    如果有多个输入参数,那么调用时,要与创建时的参数一一对应
    exec proc_销售额 '1301'
    --另一种调用:按名称调用,与参数位置无关
    exec proc_销售额 @EmployeesID='1301'
    
    
    --带输入参数的默认值的存储过程
    if exists (select * from sysobjects where name='proc_销售额')	
    drop procedure proc_销售额
    go
    create procedure proc_销售额
    @EmployeesID int='1301'
    as									
    set nocount on		
    print '编号为'+cast(@EmployeesID as char(4))+'的员工销售情况如下:'
    select 编号,姓名,销售额=case
    										when sum(G.零售价*S.数量) is null then '无销售信息'
    										else  cast(sum(G.零售价*S.数量) as char(20))
    									end 
    from Employees E left join Sell S on E.编号=S.售货员工编号 left join Goods G on G.商品编号=S.商品编号 where 编号=@EmployeesID
    group by E.编号,E.姓名
    go
    
    
    --调用有输入参数的存储过程 
    exec proc_销售额 				--使用默认值
    exec proc_销售额 '1302'		--不使用默认值
    
    --多个参数只有一个默认值调用时
    --按位置 这个默认值一般放在最后,调用时只用写不是默认值的,最后的默认值省略不写,就是调用的默认值。
    --按名称   如要使用默认值,则默认值不用写,其他按名称调用即可
    
  3. 带输出参数的存储过程的创建

    ​ 如果希望调用存储过程后,返回了一个或多个值,这时就需要使用输出函数了。

    --输出参数的存储过程
    --根据销售额判断是什么员工
    if exists (select * from sysobjects where name='proc_销售额')						
    drop procedure proc_销售额
    go
    create proc proc_销售额
    @EmployeesID int='1301', @sellsum money output
    as								
    set nocount on			
    print '编号为'+cast(@EmployeesID as char(4))+'的员工销售情况如下:'
    select 编号,姓名,销售额=case
    										when sum(G.零售价*S.数量) is null then '无销售信息'
    										else  cast(sum(G.零售价*S.数量) as char(20))
    									end 
    from Employees E left join Sell S on E.编号=S.售货员工编号 left join Goods G on G.商品编号=S.商品编号 where 编号=@EmployeesID
    group by E.编号,E.姓名
    if @EmployeesID in (select 售货员工编号 from Sell)
    	select @sellsum=sum(零售价*S.数量) from Goods G , Sell S where G.商品编号=S.商品编号 and  售货员工编号=@EmployeesID
    else
    	set @sellsum=0
    go
    
    --调用有输出参数的存储过程
    --调用时,要再定义一个变量接收输出值(类型要与输出值对应),且调用时变量后要+output
    declare @a money
    exec proc_销售额 '1302' ,@a output
    if @a>=30000
    	print '优秀员工'
    else if @a>=10000
    	print '合格员工'
    else 
    	print '无销售员工'
    
    --按名称调用
    declare @a money
    exec proc_销售额 @EmployeesID='1302' ,@sellsum=@a output
    if @a>=30000
    	print '优秀员工'
    else if @a>=10000
    	print '合格员工'
    else 
    	print '无销售员工'
    
    --使用默认值
    declare @a money
    exec proc_销售额 @sellsum=@a output
    if @a>=30000
    	print '优秀员工'
    else if @a>=10000
    	print '合格员工'
    else 
    	print '无销售员工'
    
  4. 处理存储工程的中的错误

    • 可以使用print语句显示错误信息,但是这些信息是临时的,只能显示给用户
    • raiserror 显示用户定义的错误信息时:可指定严重级别,设置系统变量@@error ,记录发生的错误等
  5. 返回值

    调用时要专门定义一个变量返回这个值,然后用输出语句输出
    

总结:

  • 存储过程是一组预编译的SQL语句,它可以包含数据操纵语句、变量、逻辑控制语句等。
  • 存储过程允许带参数,参数分为:输入参数 / 输出参数
  • 其中,输入参数可以有默认值
    • 输入参数:可以在调用时向存储过程传递参数,此类参数可用来向存储过程中传入值
    • 输出参数从存储过程中返回(输出)值,后面跟output关键字
    • raiserror语句用来向用户报告错误

练习

use XK
go

select * from Student
select * from StuCou
select * from Course
select * from Class

--1、在Xk数据库中,创建存储过程proc_学生选课情况1,完成如下功能。
--查询学生的选课信息(要求显示学号、姓名,课程名,志愿号)(1)对存储过程进行加密(2)调用存储过程

if exists (select * from sysobjects where name='proc_学生选课情况1')					
drop procedure proc_学生选课情况1
go
create procedure proc_学生选课情况1
	with encryption
	as
	set nocount on	
	print '学生选课信息如下:'
	select S.StuNo 学号,StuName 姓名,CouName 课程名,WillOrder 志愿号 from Student S ,StuCou SC ,Course C where S.StuNo=SC.StuNo and SC.CouNo=C.CouNo
go

--调用
exec proc_学生选课情况1


--2、在Xk数据库中,创建存储过程proc_学生选课情况2,完成如下功能。
--(1)查询给定学号的学生选课情况(要求显示学号、姓名,课程名,志愿号);
--(2)存储过程带1个输入参数,表示学号;
--(3)执行存储过程完成指定学号'00000001' , '00000025', '000000001'的选课信息查询

if exists (select * from sysobjects where name='proc_学生选课情况2')					
drop procedure proc_学生选课情况2
go
create procedure proc_学生选课情况2
@StuID  nvarchar(8)				--这里的类型一定要与StuNo相匹配
as
set nocount on	
if @StuId in (select StuNo from StuCou)
	begin
		print '该学生选课信息如下:'
		select S.StuNo 学号,StuName 姓名,CouName 课程名,WillOrder 志愿号 from Student S ,StuCou SC ,Course C where S.StuNo=SC.StuNo and SC.CouNo=C.CouNo and S.StuNo=@StuID
	end
else if @StuId in (select StuNo from Student)
	print '该学生无选课信息!'
else
	print '无此人,请重新输入'
go

--调用
exec proc_学生选课情况2 '00000001'	
exec proc_学生选课情况2 '00000025'	
exec proc_学生选课情况2 '000000001'	



--3、在Xk数据库中,创建存储过程proc_学生选课情况3,完成如下功能。
--(1)查询指定学号的学生的选课情况(要求显示学号、姓名、课程名称,志愿号)。
--(2)存储过程带2个参数,输入参数表示学号,输出参数用于返回每个学生的选课门数。
--(3)完成指定学号的选课情况查询,选过课程的,存储过程返回1; 若没有选过课程的则给出提示“该学生没有选过程课程!”,存储过程返回0。
--(4)选课门数等于5门,显示“已经达到选课要求!”;选课门数大于等于4门,显示“请继续选课,还差1门达到选课要求!”;选课门数等于3门,显示“请继续选课,还差2门达到选课要求!”;选课门数等于2门,显示“请继续选课,还差3门达到选课要求!”;选课门数等于1门,显示“请继续选课,还差4门达到选课要求!”
--(5)对创建存储过程的文本进行加密。
--(6)分别以'00000001' , '00000005', '00000025', '000000001'学号进行存储过程调用的测试。(执行结果如下图所示)

if exists (select * from sysobjects where name='proc_学生选课情况3')					
drop procedure proc_学生选课情况3
go
create procedure proc_学生选课情况3
@StuID  nvarchar(8) ,
@Choosesum int output
with encryption
as
set nocount on	
if @StuId in (select StuNo from StuCou)
	begin
		print '该学生选课信息如下:'
		select S.StuNo,StuName,CouName,WillOrder from Student S ,StuCou SC ,Course C where S.StuNo=SC.StuNo and SC.CouNo=C.CouNo and S.StuNo=@StuID
		select @Choosesum=count(StuName) from (	select S.StuNo,StuName,CouName,WillOrder from Student S ,StuCou SC ,Course C where S.StuNo=SC.StuNo and SC.CouNo=C.CouNo and S.StuNo=@StuID) xuanke 
		print '该学生选课门数:'+cast(@Choosesum as char(4))
		if @Choosesum=5
				print '已达到选课计划要求'
			else if @Choosesum=4
				print '请继续选课,还差1门达到选课要求!'
			else if @Choosesum=3
				print '请继续选课,还差2门达到选课要求!'
			else if @Choosesum=2
				print '请继续选课,还差3门达到选课要求!'
			else
				print '请继续选课,还差4达到选课要求!'
		return 1
	end
else if @StuId in (select StuNo from Student)
	begin
		print '该学生没有选过课程!'
		return 0
	end
else
	raiserror('非本校学生,请重新输入!',16,1)
go


--调用
declare @sum int ,@a int
exec @a=proc_学生选课情况3 '00000001',@sum output
print '返回值:'+cast(@a as char(1))

--调用
declare @sum int,@a int
exec @a=proc_学生选课情况3 '00000005',@sum output
print '返回值:'+cast(@a as char(1))

--调用
declare @sum int,@a int
exec @a=proc_学生选课情况3 '00000025',@sum output
print '返回值:'+cast(@a as char(1))

--调用
declare @sum int,@a int
exec @a=proc_学生选课情况3 '000000001',@sum output
print '返回值:'+cast(@a as char(100))

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

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

QT窗体绘图QPainter

QPainter INSCODE AI 创作助手: QPainter是Qt中的一个类,用于在窗口、图像或其他用户界面上绘制图形和文本。它提供了一些方便的方法来画线、矩形、圆、多边形和文本 QPainter绘图函数 INSCODE AI 创作助手: QPainter是Qt中一个用于绘图的类&…

MATLAB开发中的常见问题和解决方法:如何解决常见的性能和bug问题

章节一:引言 在MATLAB开发中,经常会遇到一些常见的性能和bug问题。这些问题可能导致程序运行缓慢、结果不准确或者甚至崩溃。本文将介绍一些常见问题,并提供解决方法和案例,帮助开发者更好地应对这些挑战。 章节二:性…

chatgpt赋能Python-python3多行输入

Python3多行输入教程:如何让你的输入更加高效 Python3是一种功能强大、易于学习的编程语言,被广泛应用于科学计算和数据分析领域。但是,对于初学者来说,输入数据可能是一个有些棘手的问题。在本文中,我们将介绍如何使…

chatgpt赋能Python-python3拷贝文件

Python3 拷贝文件方法及注意事项 拷贝文件在日常开发中是一项基本的操作。Python3作为一门既简洁又强大的编程语言,也提供了丰富的文件操作函数。在本篇文章中,我们将介绍如何使用Python3拷贝文件以及需要注意的细节。 为什么要拷贝文件? …

RHCE--openlab搭建网站

--作业要求-- 综合练习:请给openlab搭建web网站 ​ 网站需求: ​ 1.基于域名[www.openlab.com](http://www.openlab.com)可以访问网站内容为 welcome to openlab!!! ​ 2.给该公司创建三个子界面分别显示学生信息,教学资料和缴费网站&#x…

积水监测用什么传感器?道路积水监测设备

近年来,由于全球气候变化导致极端天气频发,在暴雨的侵袭下,许多城市都面临路面积水严重的问题,道路积水是道路交通安全和行车舒适度的一大威胁,给司机和行人带来了巨大的安全隐患。 如何解决道路积水问题? 1、强城市排…

ChatGPT又一重磅更新 - iOS官方App发布

写在前面:博主是一只经过实战开发历练后投身培训事业的“小山猪”,昵称取自动画片《狮子王》中的“彭彭”,总是以乐观、积极的心态对待周边的事物。本人的技术路线从Java全栈工程师一路奔向大数据开发、数据挖掘领域,如今终有小成…

余压传感器(探测器)最重要的两个功能是什么?

余压传感器(探测器)是什么? 余压传感器(探测器)主要用于测量两个位置之间的压差。 余压传感器(探测器)的作用? 流量测量:在管道中,通过测量两点之间的压差&…

头歌计算机组成原理实验—运算器设计(11)第11关:MIPS运算器设计

第11关:MIPS运算器设计 实验目的 学生理解算术逻辑运算单元(ALU)的基本构成,掌握 Logisim 中各种运算组件的使用方法,熟悉多路选择器的使用,能利用前述实验完成的32位加法器、 Logisim 中的运算组件构造指…

基于Freertos的ESP-IDF开发——5.使用按键[不带消抖、带消抖、长按短按识别]

基于Freertos的ESP-IDF开发——5.使用按键[不带消抖、带消抖、长按短按识别] 0. 前言1. 确定GPIO引脚2. 触发函数(不带消抖)3. 触发函数(带消抖)4. 长按和短按识别5.其他FreeRtos文章 0. 前言 这一节我们来学习使用按键操作。包括带消抖和不带消抖。 由于之前已经学习过FreeR…

chatgpt赋能Python-python3_run

Python3 Run:学习Python必须掌握的运行方式 如果你在学习Python编程,那么Python3 Run是你必须掌握的运行方式之一。Python3 Run可以让你在本地环境中运行Python代码并查看运行结果。在本文中,我们将介绍Python3 Run的基本概念、使用方法和注…

概论_第4章__协方差Cov(X)的定义和性质___相关系数的定义和性质

前面讨论的方差是 一维随机变量X, 对于二维随机变量, 怎样计算方差呢? 这就引出了 协方差: 讨论X与Y之间相互关系的数字特征。 一 协方差的定义 协方差通俗的理解: 两个随机变量X, Y协作产生的方差。 计算协方差的公式有…

SSM框架学习-Spring事务

1. 数据库中事务与Spring中的事务 数据库事务和Spring中的事务是两个不同的概念,但Spring中的事务是建立在数据库事务之上的。 数据库事务是指一组数据库操作,要么全部成功执行,要么全部回滚(撤销)。这么做是为了保证数…

【Markdown】笔记

设置-通用-开启调试模式 普通文本编辑器编写的轻量级标记语言 标题 # ~ ###### 文本 _斜体_ *斜体* **粗体** ***粗斜体*** 列表 无序 * - 有序 1. 2. 3. Tab控制层级 链接 [链接名](链接地址) <链接地址> 引用 > 嵌套 > >> >>&…

hadoop零碎知识点总结

系列文章目录 ubuntu虚拟机下搭建zookeeper集群&#xff0c;安装jdk压缩包&#xff0c;搭建Hadoop集群与spark集群的搭建 虚拟机VMware里面安装Windows sever 2003版本详细教程_vmware安装win2003 centos7配置静态网络常见问题归纳_centos7网络问题 文章目录 系列文章目录…

chatgpt赋能Python-python3_排序

Python3 排序指南&#xff1a;介绍、说明和实践 Python3是当今最受欢迎的编程语言之一&#xff0c;拥有许多可用于各种任务的库和框架。其中之一是它自带的排序函数&#xff0c;在数据分析和机器学习等领域中非常有用。 在本篇文章中&#xff0c;我们将简要介绍Python3的排序和…

Baumer工业相机堡盟工业相机IO介绍与配置(二)

Baumer工业相机堡盟工业相机IO介绍与配置&#xff08;二&#xff09; Baumer工业相机Baumer工业相机IO的功能Baumer工业相机IO的作用Baumer工业相机IO上点连线方法 Baumer工业相机 Baumer工业相机堡盟相机是一种高性能、高质量的工业相机&#xff0c;可用于各种应用场景&#…

Linux下基于TCP协议的Socket套接字编程(客户端服务端)入门详解

写在前面&#xff1a; 本篇博客探讨&实践环境如下&#xff1a; 1.操作系统&#xff1a; Linux 2.版本(可以通过命令 cat /etc/os-release 查看版本信息)&#xff1a;PRETTY_NAME“CentOS Linux 7 (Core)” 编程语言:C 一、socket 是什么&#xff1f; 常常说socket 、套接字…

chatgpt赋能Python-python3加密解密

Python3加密解密——确保你的数据安全 在今天的数字化时代&#xff0c;数据已经成为最重要的财产之一。然而&#xff0c;随着互联网的流行&#xff0c;数据泄露和非法访问变得越来越普遍。因此&#xff0c;确保数据的安全性变得非常重要。加密解密是目前最受欢迎的数据安全措施…

chatgpt赋能Python-python3_8如何下载

Python 3.8如何下载 Python 3.8是一种高级编程语言&#xff0c;具有简单易于学习和高度可读性的特点。这篇文章旨在为您提供Python 3.8的下载方法。 什么是Python 3.8 Python 3.8是Python编程语言的最新版本&#xff0c;于2019年10月发布。它引入了许多新特性和功能&#xf…