广告
返回顶部
首页 > 资讯 > 后端开发 > 其他教程 >SqlServer存储过程详解
  • 400
分享到

SqlServer存储过程详解

2024-04-02 19:04:59 400人浏览 八月长安
摘要

从存储过程返回数据 - SQL Server | Microsoft 官方文档 存储过程它是真正的脚本,更准确地说,它是批处理(batch),但都不是很确切,它存储与数据库而不是单

从存储过程返回数据 - SQL Server | Microsoft 官方文档

存储过程它是真正的脚本,更准确地说,它是批处理(batch),但都不是很确切,它存储与数据库而不是单独的文件中。

存储过程中有输入参数,输出参数以及返回值等。

一、创建存储过程:CREATE PROC

创建存储过程的方法除了他使用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

1、声明参数

声明参数需要以下几部分的信息:名称、数据类型 、默认值 、方向、

对于名称,有一组简单的规则。

  • 它必须以@符号(和变量一样)开始。此外,除了不能内嵌空格外,其规则与普通变量规则相同。
  • 数据类型和名称一样,必须像变量那样声明,采用sql Server内置的或用户自定义的数据类型。
  • 声明需要类型时需要注意,当声明CURSOR类型参数时,必须也使用VARYING和OUTPUT选项。同时,OUTPUT可以简写为OUT。

其语法如下所示:

@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 '酒';

2、提供默认值

在默认值方面,参数与变量不同。对于同样的情况,变量一般初始化为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 '如意刀狼'

输出结果如下:

3、输出参数

一个获得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

4、返回值。返回值必须是整数。

返回值可用来确定存储过程执行的状态。

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

5、执行存储过程:

对于调用存储过程需要注意以下几点:

  • 对于存储过程声明中的输出参数,需要使用OUTPUT关键字。
  • 和声明存储过程时一样,调用存储过程时,必须使用OUTPUT关键字。这样就对SQL Server作了提前通知,告诉它参数所需要的特殊处理。但需要注意的是,如果忘记包含OUTPUT关键字,不会产生运行时错误,但是输出的值不会传入变量中(变量很可能是NULL)。
  • 赋值给输出结果的变量不需要和存储过程中的内部参数拥有相同的名称。
  • EXEC(或EXECUTE)关键字是必须的,因为对存储过程的调用并不是批处理要做的第一件事(如果存储过程的调用是批处理的第一件事,则可以不使用EXEC)。

6、WITH RECOMPILE选项

可以利用存储过程提供的安全性代码和代码封装方面的好处,但还是忽略了预编译代码方面的影响。可以回避未使用正确的查询计划的问题,因为可以确保为特定一次运行创建新的计划。方法就是使用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

ALTER PROC spPerson
  AS
  SELECT * FROM Person WHERE Id = 45

三、删除存储过程:DROP PROC

DROP PROC|PROCEDURE <sproc name>[;]

四、常用存储过程

1、sp_help: 查询表的信息

sp_help Person

看一张表有那些信息,有约束,存储过程,自定义函数等等信息。

2、sp_helpdb: 查看数据库信息

sp_helpdb TestDataCenter

当然也可以不带参数,显示当前数据库连接下的所有数据库信息。

这张图几乎包含了数据库的所有信息了。有了这张图,想了解一个数据库的信息就简单了。

3、sp_helpindex: 查看有关表或视图上的索引的信息

sp_helpindex Person

注意参数中是表名,上面的Person就是表名,而不是索引名称。

4、sp_helpconstraint: 查看表上的约束信息

sp_helpconstraint Person

注意参数是表名。

5、sp_helpfile: 根据文件逻辑名称, 查看文件的信息

sp_helpfile TestDataCenter

注意参数是文件的逻辑名称。也可以不带参数,输出当前数据库的所有文件信息。

6、sp_helpfilegroup: 根据文件组名称,查看文件组信息

sp_helpfilegroup 'PRIMARY'

参数名中是文件组的逻辑名称,当然也可以不带参数,这样就仅仅输出当前数据库的文件组信息。

显示结果如下:

7、sp_helptext:显示默认值、未加密的 Transact-SQL 存储过程、用户定义 Transact-SQL 函数、触发器、计算列、CHECK 约束灯等的定义。

sp_helptext spName

返回的是什么?就是定义的代码。

到此这篇关于Sql Server存储过程的文章就介绍到这了。希望对大家的学习有所帮助,也希望大家多多支持编程网。

--结束END--

本文标题: SqlServer存储过程详解

本文链接: https://www.lsjlt.com/news/149259.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
  • SqlServer存储过程详解
    从存储过程返回数据 - SQL Server | Microsoft 官方文档 存储过程它是真正的脚本,更准确地说,它是批处理(batch),但都不是很确切,它存储与数据库而不是单...
    99+
    2022-11-13
  • SQLserver存储过程写法与设置定时执行存储过程方法详解
    目录最近工作中需要写SQLserver的存储过程,第一次使用,简单记录下,以防遗忘。 在SQLserver可视化工具中编写,我的工具如下图: 首先点击你的数据库,找到可编程性,在可...
    99+
    2023-03-13
    sqlserver 定时执行存储过程 SQLserver存储过程 sqlserver存储过程写法
  • MySQL存储过程详解 mysql 存储过程
    mysql存储过程详解 1.      存储过程简介   我们常用的操作数据库语言SQL语句在执行的时候需要要先编译,然后执行,而存储过程(Stored Proce...
    99+
    2022-10-18
  • SQLSERVER中怎么解密存储过程
    SQLSERVER中怎么解密存储过程,很多新手对此不是很清楚,为了帮助大家解决这个难题,下面小编将为大家详细讲解,有这方面需求的人可以来学习下,希望你能有所收获。  加密测试的存储过程  IF EXISTS...
    99+
    2022-10-18
  • sqlserver分页存储过程
    sqlserver 单表(视图)通用分页存储过程 create procedure proc_getpage @table_name varchar(100), --表名(视图) @select_fie...
    99+
    2019-07-22
    sqlserver分页存储过程
  • mysql 存储过程详解
    前言 在项目开发中,经常会遇到这样一种场景,当修改A表的一条数据时,需要关联修改B表、C表甚至其他更多表的数据,为什么会这样呢? 在真实的业务场景中,往往一张表的数据关联的业务是多样的,举例来说,用户在页面上完成一个订单,对服务端来说,与这...
    99+
    2023-08-17
    mysql 存储过程详解 mysql 存储过程使用 mysql 存储过程
  • Sqlserver中怎么解密加密存储过程
    Sqlserver中怎么解密加密存储过程,针对这个问题,这篇文章详细介绍了相对应的分析和解答,希望可以帮助更多想解决这个问题的小伙伴找到更简单易行的方法。 首先登录sqlser...
    99+
    2022-10-18
  • SqlServer系列笔记——存储过程
    存储过程---就像数据库中运行方法(函数)定义是一组预编译好的完成特定功能的SQL语句是存储在服务器上的一个对象可通过对象名来调用和C#里的方法一样,由存储过程名/存储过程参数组成/可以有返回结果。前面学的...
    99+
    2022-10-18
  • SQLServer中怎么修改存储过程
    这篇文章给大家介绍SQLServer中怎么修改存储过程,内容非常详细,感兴趣的小伙伴们可以参考借鉴,希望对大家能有所帮助。  初学SQLServer存储过程改怎么操作  我们假设有一个表Jobs,它的四个字...
    99+
    2022-10-18
  • SQLServer中怎么创建存储过程
    这篇文章给大家介绍SQLServer中怎么创建存储过程,内容非常详细,感兴趣的小伙伴们可以参考借鉴,希望对大家能有所帮助。打开SQL Server 2005的管理工具,选中需要创建存储过程的数据库,找到“可...
    99+
    2022-10-18
  • SQLServer分页存储过程有哪些
    本篇文章为大家展示了SQLServer分页存储过程有哪些,内容简明扼要并且容易理解,绝对能使你眼前一亮,通过这篇文章的详细介绍希望你能有所收获。  SQLServer分页存储过程有哪几种方法  创建数据库d...
    99+
    2022-10-18
  • sqlserver通用分页的存储过程
    这篇文章主要讲解了“sqlserver通用分页的存储过程”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“sqlserver通用分页的存储过程”吧! ...
    99+
    2022-10-18
  • Oracle存储过程案例详解
    创建简单存储过程(Hello World) 为了方便读者简单易懂,我将下面使用到的表复制给大家。 具体表中的数据,请大家自己填写 -- Create table create t...
    99+
    2022-11-12
  • MYSQL存储过程 注释详解
    目录1.使用说明2.准备3.语法3.1 变量及赋值3.2 入参出参3.3 流程控制-判断3.4 流程控制-循环3.5 流程控制-退出、继续循环3.6 游标3.7 存储过程中的hand...
    99+
    2022-11-12
  • SQL Server的存储过程详解
    目录存储过程的概念存储过程的优点系统存储过程用户自定义存储过程1、 创建语法2、 创建不带参数存储过程3、 修改存储过程4、 带参存储过程5、 带通配符参数存储过程6、 带输出参数存...
    99+
    2022-11-13
  • MySQL中存储过程的详细详解
    目录概述优点缺点mysql存储过程的定义存储过程的基本语句格式存储过程的使用定义一个存储过程定义一个有参数的存储过程定义一个流程控制语句 IF ELSE定义一个条件控制语句 CASE定义一个循环语句 WHILE定义一个循...
    99+
    2022-06-26
    mysql存储过程实例详解 数据库存储过程 mysql创建存储过程的语句
  • 从ASP页面运行SQLServer存储过程
    要从ASP页面运行SQLServer存储过程,可以按照以下步骤进行:1. 在ASP页面中创建数据库连接对象:```asp```注意替...
    99+
    2023-09-12
    ASP
  • sqlserver中怎么归调用存储过程
    这期内容当中小编将会给大家带来有关sqlserver中怎么归调用存储过程,文章内容丰富且以专业的角度为大家分析和叙述,阅读完这篇文章希望大家可以有所收获。递归式指代码片段调用自身的情况;危险之处在于:如果调...
    99+
    2022-10-18
  • Java中怎么调用SqlServer存储过程
    Java中怎么调用SqlServer存储过程,很多新手对此不是很清楚,为了帮助大家解决这个难题,下面小编将为大家详细讲解,有这方面需求的人可以来学习下,希望你能有所收获。  1.数据库连接packageco...
    99+
    2022-10-18
  • 分享SqlServer存储过程使用方法
    目录一、简介二、使用三、在存储过程中实现分页一、简介 简单记录一下存储过程的使用。存储过程是预编译SQL语句集合,也可以包含一些逻辑语句,而且当第一次调用存储过程时,被调用的存储过程...
    99+
    2022-11-13
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作