文章收藏-FAQ 位置:电脑学习网

学会在 ASP 中使用存储过程

    学习使用存储过程(Stored Procedure),是ASP程序员的必须课之一。所有的大型数据库都支持存储过程,比如Oracle、MS SQL等,(但MS Access不支持,不过,在Access里可以使用参数化的查询)。

    使用存储过程有许多好处,它可以封装复杂的数据逻辑,充分发挥大型数据库本身的优势。我们知道,ASP并不适合做复杂的数据运算,而通过OLD DB访问数据库,由于数据需要在ASP和数据库之间传递,相当消耗系统资源。事实上,如果数据库仅仅起着数据存储的作用,那么它的功能是远远没有得到利用的。

    关于如何创建存储过程,请参考MS SQL的相关文档。
    本文介绍存储过程如何在ASP中运用。
    简单的一个SQL语句:
    select ID,Name,Picture,Time,Duty from employ
    我们可以创建一个存储过程:
    CREATE PROCEDURE sp_employ
    AS
    select ID,Name,Picture,Time,Duty from employ
    Go

    而SQL语句:
    select ID,Name,Picture,Time,Duty from employ where ID=10230
    对应的存储过程是:(用Alter替换我们已有的存储过程)
    ALTER PROCEDURE sp_employ
    @inID  int
    AS
    select ID,Name,Picture,Time,Duty from employ  where ID=@inID
    Go

    下面对比一下SQL和存储过程在ASP中的情况。首先看看直接执行SQL的情况:
    〈%
    dim Conn, strSQL, rs
    set Conn = Server.CreateObject(“ADODB.Connection“)
    Conn.Open  “DSN=webData;uid=user;pwd=password“
    strSQL = “ select ID,Name,Picture,Time,Duty from employ “
    Set rs = Conn.Execute(strSQL)
    %〉

    再看看如何执行Stored Procedure:
    〈%
    dim Conn, strSQL, rs
    set Conn = Server.CreateObject(“ADODB.Connection“)
    Conn.Open  “DSN=webData;uid=user;pwd=password“ ’make connection
    strSQL = “sp_employ“
    Set rs = Conn.Execute(strSQL)
    %〉

    而执行带参数的Stored Procedure也是相当类似的:
    〈%
    dim Conn, strSQL, rs, myInt
    myInt = 1
    set Conn = Server.CreateObject(“ADODB.Connection“)
    Conn.Open  “DSN=webData;uid=user;pwd=password“
    strSQL = “sp_myStoredProcedure “ & myInt
    Set rs = Conn.Execute(strSQL)
    %〉

     [文章来源:“十万个为什么”电脑学习网]
     [网络地址:http://why100000.com]
     [版权声明:除本站部分特别声明禁止转载的专稿外,其他的文章可以自由转载,但请务必注明出处和原始作者。本站文章版权归文章原作者所有。如果本站转载的文章有版权问题请联系本站,我们会尽快予以更正。]
 

【字体:[大] [中] [小] 【加入收藏】 【发表评论】 【关闭本窗口】

Copyright © “十万个为什么”电脑学习网 2000-2007 陕ICP备06007929号
站务联系:MSN & Email:zhangking2008@gmail.com  QQ:9365822