存储的过程 (存储过程(数据库引擎)) 是存储在数据库中的可执行对象。
存储过程分类 系统存储过程系统存储过程是 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存储过程介绍所遇到的程序开发问题。
如果觉得内存溢出网站内容还不错,欢迎将内存溢出网站推荐给程序员好友。
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)