日期:2012-03-11  浏览次数:20984 次


    Command对象特定地为处理各种类型的命令而设计,特别是那些需要参数的命令。与Connection对象相似,Command对象可以运行返回记录集和不返回记录集两种类型的命令。实际上,如果命令不含有参数,那么它并不关心是使用Connection对象,还是Command对象,还是Recordset对象。

9.2.1 返回记录集
       对于一个返回记录集的命令,可使用Execute方法。然而,与Connection对象不同,必须使用CommandText属性,而不能在Execute方法中使用命令文本。
       Set cmdAuthors = Server.CreateObject("ADODB.Command")

       cmdAuthors.CommandText = "Authors"

       Set rsAuthors = cmdAuthors.Execute
       这是告诉Command对象去执行一个简单的、返回一个只读记录集的命令的最简单方法。
       Execute方法也有一些可选参数,如表9-2所示:
表9-2  Command对象的Execute方法的参数及说明


       参数RecordsAffected与Options同前面解释的一样,另外也可以使用CommandType属性设置命令类型:
       Set cmdAuthors = Server.CreateObject("ADODB.Command")

       cmdAuthors.CommandText = "Authors"
       cmdAuthors.CommandType = adCmdTable
       如果不设置其他参数,也可以在Execute行上设置,必须为它们使用逗号:
       Set rsAuthors = cmdAuthors.Execute(, , adCmdTable)
       在本章后面处理存储过程时,将会看到参数Parameters的用途。
       改变光标类型
       值得注意是,使用Execute方法返回的记录集具有缺省的光标类型。这意味着这是只能前移的、只读的记录集。虽然使用Execute方法不能改变这种情况,但对这个问题有一个解决的方法。
       如果需要使用一个命令,并且要求不同的光标和锁定类型,那么应该使用Recordset的Open方法,此时Command对象作为Recordset的数据源。例如:
       cmdAuthors.ActiveConnection = strConn
       cmdAuthors.CommandText = "Authors"
       cmdAuthors.CommandType = adCmdTable

       rsAuthors.Open cmdAuthors, , adOpenDynamic, adLockOptimistic
       注意,在Open命令行中忽略了连接细节,因为连接设置在Command对象中。连接细节在命令打开前已经设置在Command对象的ActiveConnection属性中。

9.2.2 操作命令
       对于操作命令,比如那些无记录返回的更新命令,整个过程相似,只需移去设置记录集的代码:
       Set cmdUpdate = Server.CreateObject("ADODB.Command")
       strSQL = "UPDATE Titles SET Price = Price * 1.10" & "WHERE Type='Business'"

       cmdUpdate.ActiveConnection = strConn
       cmdUpdate.CommandText = sSQL
       cmdUpdate.CommandType = adCmdText

       cmdUpdate.Execute , , adExecuteNoRecords
       注意,我们在此设置了命令类型,然后在Execute行中增加了额外的设置选项。这段代码运行UPDATE命令,并且保证不会创建新的记录集。
9.2.3 存储过程
       存储过程的使用是Command对象得到应用的一个领域。存储过程(有时也称存储查询)是存储在数据库中预先定义的SQL查询语句。
       为什么应该创建和使用存储过程而不是在代码中直接使用SQL字符串呢?主要有以下几个理由:
       · 存储过程被数据库编译过。这样可以产生一个“执行计划”,因此数据库确切地知道它将做什么,从而加快了过程的执行速度。
       · 存储过程通常被数据库高速缓存,这样使它们运行得更快,因为此时不需要从磁盘中读取它们。并非所有的数据库都支持这种缓存机制,比如微软的Access就不支持,而SQL Server却支持。
       · 通过指定数据库中的表只能被存储过程修改,可以确保数据更安全。这意味着具有潜在危险的SQL操作不会执行。
       · 可以避免将ASP代码和冗长的SQL语句混在一起,从而使ASP代码更易于维护。
       · 可以将所有SQL代码集中存放于服务器。
       · 可以在存储过程中使用输出参数,允许返回记录集或其他的值。
       一般说来,存储过程几乎总是比相当的SQL语句执行速度快。
       为了使用存储过程,只要将存储过程的名字作为命令文本,并设置相应的类型。例如,考虑前面更新书价的例子。如果在SQL Server上创建一个存储过程,可以编写代码:
       CREATE PROCEDURE usp_UpdatePrices
       AS
              UPDATE Titles