欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  IT编程

SQLServer之存储过程简介

程序员文章站 2022-07-05 17:18:21
存储过程定义 存储的过程 (存储过程(数据库引擎)) 是存储在数据库中的可执行对象。 存储过程分类 系统存储过程 系统存储过程是 SQL Server系统自身提供的存储过程,可以作为命令执行各种操作。 系统存储过程主要用来从系统表中获取信息,使用系统存储过程完成数据库服务器的管理工作,为系统管理员提 ......

存储过程定义

存储的过程 (存储过程(数据库引擎)) 是存储在数据库中的可执行对象。

存储过程分类

系统存储过程

  系统存储过程是 sql server系统自身提供的存储过程,可以作为命令执行各种操作。

  系统存储过程主要用来从系统表中获取信息,使用系统存储过程完成数据库服务器的管理工作,为系统管理员提供帮助,为用户查看数据库对象提供方便,系统存储过程位于数据库服务器中,并且以sp_开头,系统存储过程定义在系统定义和用户定义的数据库中,在调用时不必在存储过程前加数据库限定名。sql server服务器中许多的管理工作都是通过执行系统存储过程来完成的,许多系统信息也可以通过执行系统存储过程来获得。

  系统存储过程创建并存放在与系统数据库master中,一些系统存储过程只能由系统管理员使用,而有些系统存储过程通过授权可以被其它用户所使用。

用户存储过程(自定义存储过程)

  自定义存储过程即用户使用t_sql语句编写的、为了实现某一特定业务需求,在用户数据库中编写的t_sql语句集合,自定义存储过程可以接受输入参数、向客户端返回结果和信息,返回输出参数等。创建自定义存储过程时,存储过程名前加上"##"表示创建了一个全局的临时存储过程;存储过程前面加上"#"时,表示创建的局部临时存储过程。局部临时存储过程只能在创建它的回话中使用,会话结束时,将被删除。这两种存储过程都存储在tempdb数据库中。

用户定义的存储过程分为两类:t_sql 和clr

t_sql:存储过程是值保存的t_sql语句集合,可以接受和返回用户提供的参数,存储过程也可能从数据库向客户端应用程序返回数据。

clr存储过程是指引用microsoft.net framework公共语言的方法存储过程,可以接受和返回用户提供的参数,它们在.net framework程序集是作为类的公共静态方法实现的。

扩展存储过程

扩展存储过程是以在sql server环*执行的动态连接(dll文件)来实现的,可以加载到sql server实例运行的地址空间中执行,扩展存储过程可以用sql server扩展存储过程api编程,扩展存储过程以前缀"xp_"来标识,对于用户来说,扩展存储过程和普通话存储过程一样,可以用相同的方法来执行。 

存储过程创建

存储过程可以有零个或多个参数。

你可以使用存储的过程调用从外部例程 microsoft sql server analysis services。

你可以在任何公共语言运行时 (clr) 语言(例如 c、c++、c#、visual basic 或 visual basic .net)中编写由存储过程调用的外部例程。

存储过程可以一次创建并从许多上下文中进行调用,例如其他存储过程、计算度量值或客户端应用程序。 

程序集通过使通用代码可以一次开发并存储在单个位置中,简化analysis services 数据库开发和实现。 

存储过程可用来向应用程序中添加 mdx 的本机功能未提供的商业功能。

存储过程输入

通过指定过程参数,调用程序可以将值传递给过程的主体。 

在执行过程期间,这些值可以用于各种目的。 

如果将参数标记为 output 参数,则过程参数还可以将值返回给调用程序。

一个过程最多可以有 2100 个参数,每个参数都有名称、数据类型和方向。 还可以为参数指定默认值(可选)。

存储过程调用

可以在服务器上或从客户端应用程序中调用存储过程。 

在任何一种情况下,存储过程都始终运行于服务器上,或者使用服务器的上下文,或者使用数据库的上下文。 

执行存储过程时,不需要具备特殊的权限。 

存储过程由程序集添加到服务器或数据库上下文后,只要用户的角色允许执行存储过程所执行的操作,则任何用户均可执行该存储过程。

存储过程输出

过程中的每一条 select 语句都生成一个结果集。

过程可以通过输出参数返回数据。

过程可以具有整数返回代码。

存储过程优点

1、提高性能。

2、降低网络开销。

3、提供更好的一致性。

4、提高准确性。

5、增加功能。

存储过程缺点

1、数据库移植不方便,存储过程依赖与数据库管理系统, sql server 存储过程中封装的操作代码不能直接移植到其他的数据库管理系统中。

2、不支持面向对象的设计,无法采用面向对象的方式将逻辑业务进行封装,甚至形成通用的可支持服务的业务逻辑框架。

3、代码可读性差,不易维护。不支持集群。

4、不便于调试。