SqlServer存储过程介绍

SqlServer存储过程介绍,第1张

概述存储过程定义 存储的过程 (存储过程(数据库引擎)) 是存储在数据库中的可执行对象。 存储过程分类 系统存储过程   系统存储过程是 SQL Server系统自身提供的存储过程,可以作为命令执行各种 *** 作。   系统存储过程主要用来从系统表中获取信息,使用系统存储过程完成数据库服务器的管理工作,为系统管理员提供帮助,为用户查看数据库对象提供方便,系统存储过程位于数据库服务器中,并且以sp_开头,系统 存储过程定义

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

存储过程分类 系统存储过程

  系统存储过程是 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、不便于调试。

总结

以上是内存溢出为你收集整理的SqlServer存储过程介绍全部内容,希望文章能够帮你解决SqlServer存储过程介绍所遇到的程序开发问题。

如果觉得内存溢出网站内容还不错,欢迎将内存溢出网站推荐给程序员好友。

欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/sjk/1176257.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2022-06-02
下一篇 2022-06-02

发表评论

登录后才能评论

评论列表(0条)

保存