如何掌握Sql Server存储过程,哪些知识要了解
Admin 2022-08-02 群英技术资讯 387 次浏览
从存储过程返回数据 - SQL Server | Microsoft 官方文档
存储过程它是真正的脚本,更准确地说,它是批处理(batch),但都不是很确切,它存储与数据库而不是单独的文件中。
存储过程中有输入参数,输出参数以及返回值等。
创建存储过程的方法除了他使用AS关键字外,和创建数据库中任何其他对象一样。存储过程的基本语法如下:
在语法中,PROC是PROCEDURE的缩写,两个选项的意思一样。在对存储过程命名完之后,接着是参数列表。参数是可选的。关键字AS其后就是实际的代码。
CREATE PROCEDURE|PROC <sproc name> [ [schema.] <data type> [VARYING] [=] [OUT[PUT]] [READONLY] [, [schema.] <data type> [VARYING] [=] [OUT[PUT]] [READONLY] [,... ... ]] [WITH RECOMPILE | ENCRYPTION | [EXECUTE AS { CALLER | SELF | OWNER | <'user name'>}] AS <code> | EXTERNAL NAME <assembly name>.<assembly class>.<method>
简单的存储过程示例:
CREATE PROC spPerson AS SELECT * FROM Person
执行存储过程:
EXEC spPerson
声明参数需要以下几部分的信息:名称、数据类型 、默认值 、方向、
对于名称,有一组简单的规则。
其语法如下所示:
@parameter_name [AS] datatype [=default|NULL] [VARYING] [OUTPUT | OUT]
一个需要传入参数的存储过程示例:
CREATE PROC spName @Name nvarchar(50) AS SELECT Name FROM Person WHERE Name LIKE @Name + '%';
执行存储过程:
EXEC spName '酒';
在默认值方面,参数与变量不同。对于同样的情况,变量一般初始化为NULL值,而参数不是。事实上,如果不提供默认值,则会假设参数是必须的,并且当调用存储过程时需要提供一个初始值。
为了使参数是可选的,必须提供默认值。方法是在数据类型后在逗号之前添加"="符号和作为默认值的值。这样,存储过程的用户可以有决定对此参数不提供值或是提供他们自己的值。
创建一个存储过程如下:
CREATE PROC spName @Name nvarchar(50) = NULL AS IF @Name IS NOT NULL SELECT * FROM Person WHERE NAME = @Name ELSE SELECT * FROM Person WHERE Id = 45
执行如下语句:
EXEC spName EXEC spName '如意刀狼'
输出结果如下:
一个获得OUTPUT参数的存储过程:
CREATE PROC InsertPerson @Id int OUTPUT --必须注明为OUTPUT AS INSERT INTO Person VALUES('刘备',22,190,'不详','未婚','幼儿园','不详',4999999) SET @Id = @@IDENTITY
执行存储过程:
DECLARE @Id int --实际上,调用时名称可以不同,例如也可以为@Num,@i等等。 EXEC InsertPerson @Id OUTPUT --注意此处也要有OUTPUT SELECT @Id
返回值可用来确定存储过程执行的状态。
SQL Server默认会在完成存储过程时自动返回一个0值。
为了从存储过程向调用代码传递返回值,只需要使用RETURN语句。
RETURN []
要特别注意的是:返回值必须是整数。
关于RETURN语句,最重要的是知道它是无条件地从存储过程中退出的。无论运行到存储过程的哪个位置,在调用RETURN语句之后将不会执行任何一行代码。
下面的存储过程,让其返回一个指定的值,以指示执行状态。
CREATE PROC spTestReturns AS DECLARE @MyMessage nvarchar(50); DECLARE @MyOtherMessage nvarchar(50); SELECT @MyMessage = '第一个RETURN'; PRINT @MyMessage; RETURN 100; --将这里改成返回100 SELECT @MyOtherMessage = '第二个RETURN'; PRINT @MyOtherMessage; RETURN;
执行之后,显示结果如下:
DECLARE @Return int EXEC @Return = spTestReturns //第一个RETURN SELECT @Return //返回100
对于调用存储过程需要注意以下几点:
可以利用存储过程提供的安全性代码和代码封装方面的好处,但还是忽略了预编译代码方面的影响。可以回避未使用正确的查询计划的问题,因为可以确保为特定一次运行创建新的计划。方法就是使用WITH RECOMPILE选项。
使用该选项的方式有两种:
1、可以在运行时包含WITH RECOMPILE。这告诉SQL Server抛弃已有的执行计划并且创建一个新的计划-但只是这一次。也就是说,只是这次使用WITH RECOMPILE选项来执行存储过程。
EXEC spMySproc '1/1/2004' WITH RECOMPILE
2、也可以通过在存储过程中包含WITH RECOMPILE选项来使之变得更持久。
如果使用这种方式,则在CREATE PROC或ALTER PROC语句中的AS语句前添加WITH RECOMPILE选项即可。如果通过该选项创建存储过程,那么无论在运行时选择了其他什么选项,每次运行存储过程都会重新编译它。
ALTER PROC spPerson AS SELECT * FROM Person WHERE Id = 45
DROP PROC|PROCEDURE <sproc name>[;]
sp_help Person
看一张表有那些信息,有约束,存储过程,自定义函数等等信息。
sp_helpdb TestDataCenter
当然也可以不带参数,显示当前数据库连接下的所有数据库信息。
这张图几乎包含了数据库的所有信息了。有了这张图,想了解一个数据库的信息就简单了。
sp_helpindex Person
注意参数中是表名,上面的Person就是表名,而不是索引名称。
sp_helpconstraint Person
注意参数是表名。
sp_helpfile TestDataCenter
注意参数是文件的逻辑名称。也可以不带参数,输出当前数据库的所有文件信息。
sp_helpfilegroup 'PRIMARY'
参数名中是文件组的逻辑名称,当然也可以不带参数,这样就仅仅输出当前数据库的文件组信息。
显示结果如下:
sp_helptext spName
返回的是什么?就是定义的代码。
免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:mmqy2019@163.com进行举报,并提供相关证据,查实之后,将立刻删除涉嫌侵权内容。
猜你喜欢
SQL视图无非就是存储在数据库中并具有名字的 SQL 语句,或者说是以预定义的 SQL 查询的形式存在的数据表的成分。视图可以包含表中的所有列,或者仅包含选定的列。视图可以创建自一个或者多个表,这取决于创建该视图的 SQL 语句的写法。
本文详细讲解了Sql Server的存储过程,文中通过示例代码介绍的非常详细。对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
这篇文章主要介绍了SQL Server查看未释放游标的方法的相关资料,需要的朋友可以参考下
SQL*Loader(SQLLDR)是Oracle的高速批量数据加载工具。这是一个非常有用的工具,可用于多种平面文件格式向Oralce数据库中加载数据,本文给大家分享sqlloader怎么使用的相关资料,感兴趣的朋友一起学习吧
这篇文章给大家分享的是有关sqlserver分页的内容,主要介绍4种sqlserver分页方法,分别三重循环、利用max、利用row_number关键字和offset /fetch next,下文有具体示例供大家参考学习。
成为群英会员,开启智能安全云计算之旅
立即注册Copyright © QY Network Company Ltd. All Rights Reserved. 2003-2020 群英 版权所有
增值电信经营许可证 : B1.B2-20140078 粤ICP备09006778号 域名注册商资质 粤 D3.1-20240008