中国站长下载-为中国站长提供最好最全的建站资源! 首 页发布资源有事留言繁體中文
设为首页
加入收藏
联系我们
 
您当前的位置:中国站长下载 -> 文章中心 -> 数据库区 -> MSSQL -> 文章内容  虚拟主机 域名注册 退出登录 用户管理
栏目导航
· ACCESS · MSSQL
· Mysql · DB2
· ORACLE · SYBASE
· 其他相关
热门文章
· sndvol32 - sndvol3...
· [组图] FLASH:《大话李白》...
· 个人网站到底能赚多...
· [图文] Rundll.exe是病毒吗...
· [组图] Flash:制作MV
· 价值12万元的网站SE...
· 网站创业者,你需要...
· 一个成功的网站设计...
· [图文] FLASH:韩国导航条解...
· 中国网站的赚钱模式...
相关文章
· ado.net获取存储过程...
· asp.net调用存储过程...
· 使用Data Access Ap...
· 各种存储过程使用指...
· 存储过程入门
· ASP开发中存储过程应...
· ASP开发中存储过程应...
· ASP开发中存储过程应...
· asp存储过程使用(1...
· asp存储过程使用 (...
创建存储过程
作者:佚名  来源:不详  发布时间:2006-5-9 16:47:17  发布人:chinazhan

 减小字体 增大字体


在MS SQL Server 2000 中,创建一个存储过程有两种方法:一种是使用Transaction-SQL命令Create Procedure, 另一种是使用图形化管理工具Enterprise Manager。 用Transaction-SQL 创建存储过程是一种较为快速的方法,但对于初学者,使用Enterprise Manager 更易理解,更为简单。
当创建存储过程时,需要确定存储过程的三个组成部分;
  • 所有的输入参数以及传给调用者的输出参数。
  • 被执行的针对数据库的操作语句,包括调用其它存储过程的语句;
  • 返回给调用者的状态值,以指明调用是成功还是失败。
12.2.1 使用Enterprise Manager 创建存储过程
按照下述步骤用Enterprise Manager 创建一个存储过程:
  • 启动Enterprise Manager, 登录到要使用的服务器。
  • 选择要创建存储过程的数据库,在左窗格中单击Stored Procedure 文件夹,此时在右窗格中显示该数据库的所有存储过程,如图12-1 所示。
  • 右击Stored Procedure 文件夹,在弹出菜单中选择New Stored Procedure, 此时打开创建存储过程对话框,如图12-2 所示。
  • 输入存储过程正文。
  • 单击Check Syntax, 检查语法是否正确。
  • 单击OK, 保存。
  • 在右窗格中,右击该存储过程,在弹出菜单中选择All task, 选择ManagePermissions, 设置权限,如图12-3 所示。
12.2.2 用CREATE PROCEDURE 命令创建存储过程
通过运用Create Procedure 命令能够创建存储过程,在创建存储过程之前,应该考虑到以下几个方面:
  • 在一个批处理中,Create Procedure 语句不能与其它SQL 语句合并在一起;
  • 数据库所有者具有默认的创建存储过程的权限,它可把该权限传递给其它的用户;
  • 存储过程作为数据库对象其命名必须符合命名规则;
  • 只能在当前数据库中创建属于当前数据库的存储过程。
用Create Procedure 创建存储过程的语法规则如下:
CREATE PROC [ EDURE ] procedure_name [ ; number ]
[ { @parameter data_type }
[ VARYING ] [ = default ] [ OUTPUT ]
] [ ,...n ]
[ WITH
{ RECOMPILE | ENCRYPTION | RECOMPILE , ENCRYPTION } ]
[ FOR REPLICATION ]
AS sql_statement [ ...n ]

各参数的含义如下:
  • procedure_name
    是要创建的存储过程的名字,它后面跟一个可选项number, 它是一个整数,用来区别一组同名的存储过程。存储过程的命名必须符合命名规则,在一个数据库中或对其所有者而言,存储过程的名字必须惟一。
  • @parameter
    是存储过程的参数。在Create Procedure 语句中,可以声明一个或多个参数。当调用该存储过程时,用户必须给出所有的参数值,除非定义了参数的缺省值。若参数的形式以@parameter=value 出现,则参数的次序可以不同,否则用户给出的参数值必须与参数列表中参数的顺序保持一致。若某一参数以@parameter=value 形式给出,那么其它参数也必须以该形式给出。一个存储过程至多有1024 个参数。
  • Data_type
    是参数的数据类型。在存储过程中,所有的数据类型包括text 和image 都可被用作参数。但是,游标cursor 数据类型只能被用作OUTPUT 参数。当定义游标数据类型时,也必须对VARING 和OUTPUT 关键字进行定义。对可能是游标型数据类型的OUTPUT 参数而言,参数的最大数目没有限制。
  • VARYING
    指定由OUTPUT 参数支持的结果集,仅应用于游标型参数。
  • Default
    是指参数的缺省值。如果定义了缺省值,那么即使不给出参数值,则该存储过程仍能被调用。缺省值必须是常数,或者是空值。
  • OUTPUT
    表明该参数是一个返回参数。用OUTPUT 参数可以向调用者返回信息。Text 类型参数不能用作OUTPUT 参数。
  • RECOMPILE
    指明SQL Server 并不保存该存储过程的执行计划,该存储过程每执行一次都又要重新编译。
  • ENCRYPTION
    表明SQL Server 加密了syscomments 表,该表的text 字段是包含有Create procedure语句的存储过程文本,使用该关键字无法通过查看syscomments 表来查看存储过程内容。
  • FOR REPLICATION
    选项指明了为复制创建的存储过程不能在订购服务器上执行,只有在创建过滤存储过程时(仅当进行数据复制时过滤存储过程才被执行),才使用该选项。FOR REPLICATION与WITH RECOMPILE 选项是互不兼容的。
  • AS
    指明该存储过程将要执行的动作。
  • Sql_statement
    是任何数量和类型的包含在存储过程中的SQL 语句。
另外应该指出,一个存储过程的最大尺寸为128M, 用户定义的存储过程必须创建在当前数据库中。
下面将给出几个例子,用来详细介绍如何创建包含有各种保留字的存储过程。




   asp">存储过程
 
[] [返回上一页] [打 印] [收 藏]
上一篇文章:管理存储过程
下一篇文章:存储过程概述
∷相关文章评论∷    (评论内容只代表网友观点,与本站立场无关!) [更多评论...]
中国站长下载
中国站长下载

本页只接受PR>=4 IT类站点连接,申请连接,谢谢您们的支持!希望我们的下载站能够真正帮到中国的站长们!
关于本站 - 网站帮助 - 广告合作 - 下载声明 - 友情连接 - 网站地图
Copyright © 2005-2006 ChinaZhan.Net. All Rights Reserved .