计算机教程

当前位置:3522.com > 计算机教程 > Sql Server 存储过程调用存储过程接收输出参数返回

Sql Server 存储过程调用存储过程接收输出参数返回

来源:http://www.4sports-uk.com 作者:3522.com 时间:2020-03-18 13:21

创建存储过程:

什么是存储过程:

ALTER PROCEDURE [dbo].[GetCustomers] (@rowcount INT OUTPUT) AS SELECT [CustomerID] ,[CompanyName] ,[ContactName] ,[ContactTitle] ,[Address] ,[City] ,[Region] ,[PostalCode] ,[Country] ,[Phone] ,[Fax] FROM [Northwind].[dbo].[Customers] SET @rowcount=@@rowcount 

        存储过程(Procedure)类似于C#语言中的方法,它是SQL语句和控制流语句的预编译集合。存储过程存储在数据库内,可由应用程序通过一个调用执行,而且允许用户声明变量、逻辑控制语句以及其他强大的编程功能。

接收输出参数:

        存储过程可包含逻辑控制语句和数据操作语句,它可以接收参数、输出参数、返回单个或多个结果集以及返回值。

DECLARE @count INT EXECUTE GetCustomers @count OUTPUT PRINT @count 

        存储过程在创建时即在服务器上进行编译,所以执行起来比单个SQL语句快。

2,带返回值

        类似于C#中的类库,SQL Server 提供了一些预编译的存储过程,这些存储过程称为“系统存储过程”。

创建存储过程:

 

ALTER PROCEDURE [dbo].[GetCustomers] AS SELECT [CustomerID] ,[CompanyName] ,[ContactName] ,[ContactTitle] ,[Address] ,[City] ,[Region] ,[PostalCode] ,[Country] ,[Phone] ,[Fax] FROM [Northwind].[dbo].[Customers] RETURN @@rowcount 

SQL Server中的存储过程的特征如下:

接收返回值:

        1>接收输入参数,并向调用过程或语句返回值。

DECLARE @count INT EXECUTE @count=GetCustomers PRINT @count 

        2>包含在数据库中执行操作或调用其他存储过程的编程语句。

以上所述是小编给大家介绍的Sql Server 存储过程调用存储过程接收输出参数返回值,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对脚本之家网站的支持!

        3>向调用过程返回状态值,指示执行过程是否成功(如果失败,还返回失败原因)

 

使用存储过程有下列优点:

        1>允许模块化程序设计

只需创建一次存储过程并将其存储在数据库中,所以即可在程序中调用该过程任意次。

        2>允许更快地执行

如果某操作需要大量的T-SQL代码或需要重复执行,存储过程将比T-SQL批处理代码的执行要快。将在创建存储过程时对其进行分析和优化,并可在首次执行该过程后使用该过程内存中的版本。但如果使用T-SQL批处理代码,每次运行T-SQL语句时,都要从客户端重复发送,并且在SQL-Server每次执行这些语句时,都要对其进行编译和优化。

        3>减少网络流量

创建使用存储过程后,一个需要数百行T-SQL代码的操作,由一条执行该过程代码的单独语句就可实现,而不需要在网络中发送数百行代码

        4>可作为安全机制使用

即使对于没有直接执行存储过程中语句的权限的用户,也可授予他们执行该存储过程的权限

 

存储过程分为以下两类:

        1>系统存储过程

        2>用户自定义存储过程

 

常用的系统存储过程:

sp_databases:列出服务器上的所有数据库

sp_helpdb:报告有关指定数据库或所有数据库的信息

sp_renamedb:更改数据库的名称

sp_tables:返回当前环境下可查询的对象的列表

sp_columns:返回某个表列的信息

sp_help:查看某个表的所有信息

sp_helpconstraint:查看某个表的约束

sp_helpindex:查看某个表的索引

sp_stored_procedures:列出当前环境中的所有存储过程

sp_password:添加或修改登录账户的密码

sp_helptext:显示默认值、未加密的存储过程、用户定义的存储过程、触发器或视图的实际文本

另外,还有一个常用的扩展存储过程:xp_cmdshell,它可以完成DOS命令下的一些操作,诸如创建文件夹、列出文件列表等。

本文由3522.com发布于计算机教程,转载请注明出处:Sql Server 存储过程调用存储过程接收输出参数返回

关键词: 3522.com