SQL Server 7.0 入门(五)

黄舟
发布: 2016-12-24 17:39:14
原创
1000人浏览过

使用sql server开发应用程序
编写存储过程与触发器
       存储过程和触发器是由用户创建的、驻留在服务器的一组transact sql查询语句。触发器是系统在特定条件下执行的。存储过程能够改善应用程序的性能。当客户程序需要访问数据时,一般要经过5个步骤才能访问到数据:
1)  查询语句被发送到服务器。
2)  服务器编译sql代码。
3)  优化产生查询的执行计划。
4)  数据引擎执行查询。
5)  结果发回客户程序。
存储过程是在创建时编译的,当存储过程第一次执行时,sql server产生查询执行计划并将其存储进来,以利于将来使用。当通过存储过程发出一个请求时,上述的第2和第3步就没有了,这能大大改善系统的性能。即使在第1步上也能提高性能。因为此时发送到服务器的语句只是一条存储过程的execute语句,而不是庞大的、复杂的查询。这种特性能降低网络的流量。
除了性能方面的改善外,存储过程还提供了方便地集中维护应用程序的功能。如果将查询嵌入到应用程序中。而又需要对查询进行改变,则应用程序需要重新编译,并重新发布到所有的客户端。而在存储过程中,修改对用户而言是透明的,它只需要在服务器上重新编译存储过程。
存储过程还能提供安全机制,尽管用户可能无权执行存储过程中的命令,但它却可能有权执行存储过程本身。有时候,系统管理员不会给用户以数据修改(update、insert和delete)的权力。创建的存储过程却能进行这些操作。当然用户需要拥有执行该存储过程的权力。

建立存储过程
       存储过程可以达到以下目的:
       · 带参数。
       · 返回状态值。
       · 调用其它存储过程。
       · 在远程服务器上执行。
       存储过程在“sysobjects”系统表中有一个表项,其类型为“p”。存储过程的文本存储在“syscomments”系统表中。创建存储过程需要使用transact sql命令create procedure。
       例如:
       use pubs
       go
       
       create procedure ap_getauthorsforpublisher
       as
       select a.au_lname,a.au_fname
       from authors a, titleauthor ta, titles t, publishers p
       where a.au_id = ta.au_id
       and ta.title_id = t.title_id
       and t.pub_id = p.pub_id
       and p.pub_name = ’new moon books’
       go

       create procedure语句的语法如下:
       create proc[dure] procedure_name [;number]
              [@parameter_name ][output] [,_n] ]
              [with {recompile | encryption}]
              [for replication]
       as
       number是用来对相同名字的过程进行分组的整数。分组是将所有的过程通过drop procedure语句组合到一个分组中。
       @parameter_name指定参数的名称。
       recompile表示每次执行过程时都要进行编译。
       encryption表示过程的文本在“syscomments”表中要加密。
       for replication表示过程不能在提交服务器上执行。

将参数传递给存储过程
       存储过程能够接受参数。
       注意:过程的参数也可以是用户定义的数据类型。

给参数一个缺省值
       用户还可以为存储过程中的参数定义缺省值。当在执行时没有提供所需的参数时,系统就使用缺省值作为参数。如果既没有定义缺省值,又没有在执行时提供参数,则sql server就会返回一个错误。在存储过程中定义缺省值,并使用一些逻辑检测是否指定了参数从而采取相应的行动,这是一种很好的习惯。
       例如:
       use pubs
       go
       
       create procedure ap_getauthorsforpublisher
       @publishername varchar(40) = ‘new moon books’
       as
       select a.au_lname,a.au_fname
       from authors a, titleauthor ta, titles t, publishers p
       where a.au_id = ta.au_id
       and ta.title_id = t.title_id
       and t.pub_id = p.pub_id
       and p.pub_name = @publishername
       go

 以上就是SQL Server 7.0 入门(五)的内容,更多相关内容请关注PHP中文网(www.php.cn)!

MagicStudio
MagicStudio

图片处理必备效率神器!为你的图片提供神奇魔法

MagicStudio 102
查看详情 MagicStudio
最佳 Windows 性能的顶级免费优化软件
最佳 Windows 性能的顶级免费优化软件

每个人都需要一台速度更快、更稳定的 PC。随着时间的推移,垃圾文件、旧注册表数据和不必要的后台进程会占用资源并降低性能。幸运的是,许多工具可以让 Windows 保持平稳运行。

下载
来源:php中文网
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
最新问题
开源免费商场系统广告
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板
关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新 English
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送
PHP中文网APP
随时随地碎片化学习

Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号