sql server 2008学习10 存储过程

本文涉及的产品
云数据库 RDS SQL Server,基础系列 2核4GB
RDS SQL Server Serverless,2-4RCU 50GB 3个月
推荐场景:
简介:

输入输出参数:

给存储过程传参数,叫做输入参数,用户告诉存储过程需要 利用这个参数干些什么.

输出参数: 从存储过程得到那些数据.

 

创建一个可选参数的存储过程:

 

create proc pa1
@name varchar(50)=NULL
as
if(@name is not null)
   select * from a where name like @name+'%';
else
   select * from a

exec pa1  image

exec pa1 a image

 

创建输出参数:

使用输出参数 传递 最后一次插入的标识列的值:

 

create proc pa2
    @id int output
    as
    insert into a(name) values('5')
    set @id=@@identity

执行这个存储过程:

declare @id int
exec pa2 @id out
print @id

结果如下:

image

 

返回值:

创建有返回值的存储过程:
create proc pa5
as
declare @mess varchar(50)
set @mess='exit'
print @mess;
return;

执行:

declare @result varchar(50)
exec @result=pa5
select @result

结果:

 

imageimage

 

错误处理:

可以使用 @@error

 

use test
go

if exists(select *  from sysobjects where name='pa6')
drop proc pa6
go
create proc pa6
@name nvarchar(50),
@ss int
as
declare @error int
insert into b values(@name,@ss);

set @error=@@error

if @error=0
   print 'new record is inserted' ;
   else
   begin
   if @error=547
   print 'at least one provided parameter was not found,correct an retry';
   else
   print ' unknown error occurred'
   
   end

下面使用try/catch

什么是 内联错误: 那些能让sql server 继续运行,但是因为某种原因而不能 成功完成指定任务的错误.

 

手动引发错误:

raiserror(message_ID,级别,state)

可以查看 sql server 提供的所有错误消息: select * from master.sys.messages

 

存储过程的优点:

  1. 可复用
  2. 安全性.可以创建一个返回结果集的存储过程而不用赋予用户访问底层数据表的权限.   

存储过程和性能

下面看一下存储过程是如何工作的:

image

首先运行 create proc过程,这回解析查询 以确保会实际运行这些代码.它与 直接运行脚本的区别在于:

create proc可以利用所谓的 延迟对象解析. 可以忽略一些对象还不存在的实施,这就可以稍后创建这些对象.

在创建存储过程之后,它将等待第一次执行.在那时,存储过程呗优化,而查询计划被 编译并且 缓存到系统上.

后续几次运行此过程时,除非使用 with recompile选项指定,否则都会使用缓存的查询计划. 意味着每次使用存储过程

时,存储过程都会跳过很多优化和编译工作.

如果想 在每次执行存储过程时都自动重新编译,那么可以这样做:

create proc pa1
with recompile   --这句可以实现
 as 
select * from a

 

递归:

计算阶乘

create proc aa
@vin int,
@vout int out
as
declare @inv int
declare @outv int

 if @vin !=1
     begin
         select @inv=@vin-1;
         exec aa @inv,@outv out;
         select @vout=@vin*@outv;
     end
 else
     begin
         select @vout=1;
     end 
 return ;
 go

 

执行此过程:

declare @inv int;
 declare @outv int;
 set @inv=5;
 exec aa @inv,@outv out;
 print cast(@outv as varchar(30))

结果:

image

本文转自左正博客园博客,原文链接:http://www.cnblogs.com/soundcode/archive/2012/09/11/2680002.html ,如需转载请自行联系原作者
相关实践学习
使用SQL语句管理索引
本次实验主要介绍如何在RDS-SQLServer数据库中,使用SQL语句管理索引。
SQL Server on Linux入门教程
SQL Server数据库一直只提供Windows下的版本。2016年微软宣布推出可运行在Linux系统下的SQL Server数据库,该版本目前还是早期预览版本。本课程主要介绍SQLServer On Linux的基本知识。 相关的阿里云产品:云数据库RDS SQL Server版 RDS SQL Server不仅拥有高可用架构和任意时间点的数据恢复功能,强力支撑各种企业应用,同时也包含了微软的License费用,减少额外支出。 了解产品详情: https://www.aliyun.com/product/rds/sqlserver
相关文章
|
3月前
|
存储 SQL 数据库
SQL Server存储过程的优缺点
【10月更文挑战第18天】SQL Server 存储过程具有提高性能、增强安全性、代码复用和易于维护等优点。它可以减少编译时间和网络传输开销,通过权限控制和参数验证提升安全性,支持代码共享和复用,并且便于维护和版本管理。然而,存储过程也存在可移植性差、开发和调试复杂、版本管理问题、性能调优困难和依赖数据库服务器等缺点。使用时需根据具体需求权衡利弊。
|
28天前
|
SQL 存储 关系型数据库
【MySQL基础篇】全面学习总结SQL语法、DataGrip安装教程
本文详细介绍了MySQL中的SQL语法,包括数据定义(DDL)、数据操作(DML)、数据查询(DQL)和数据控制(DCL)四个主要部分。内容涵盖了创建、修改和删除数据库、表以及表字段的操作,以及通过图形化工具DataGrip进行数据库管理和查询。此外,还讲解了数据的增、删、改、查操作,以及查询语句的条件、聚合函数、分组、排序和分页等知识点。
【MySQL基础篇】全面学习总结SQL语法、DataGrip安装教程
|
2月前
|
SQL 安全 前端开发
Web学习_SQL注入_联合查询注入
联合查询注入是一种强大的SQL注入攻击方式,攻击者可以通过 `UNION`语句合并多个查询的结果,从而获取敏感信息。防御SQL注入需要多层次的措施,包括使用预处理语句和参数化查询、输入验证和过滤、最小权限原则、隐藏错误信息以及使用Web应用防火墙。通过这些措施,可以有效地提高Web应用程序的安全性,防止SQL注入攻击。
78 2
|
3月前
|
存储 SQL 缓存
SQL Server存储过程的优缺点
【10月更文挑战第22天】存储过程具有代码复用性高、性能优化、增强数据安全性、提高可维护性和减少网络流量等优点,但也存在调试困难、移植性差、增加数据库服务器负载和版本控制复杂等缺点。
183 1
|
3月前
|
存储 SQL 数据库
Sql Server 存储过程怎么找 存储过程内容
Sql Server 存储过程怎么找 存储过程内容
235 1
|
3月前
|
存储 SQL 数据库
SQL Server存储过程的优缺点
【10月更文挑战第17天】SQL Server 存储过程是预编译的 SQL 语句集,存于数据库中,可重复调用。它能提高性能、增强安全性和可维护性,但也有可移植性差、开发调试复杂及可能影响数据库性能等缺点。使用时需权衡利弊。
|
存储 SQL
sql_存储过程、函数、分支、循环
sql_存储过程、函数、分支、循环
142 0
|
存储 SQL 安全
SQL 存储过程和函数的对比、变量、条件和处理程序、游标、流程控制详解+代码示例
SQL 存储过程和函数的对比、变量、条件和处理程序、游标、流程控制详解+代码示例
|
SQL 存储 数据安全/隐私保护

热门文章

最新文章