日期:2008-09-03  浏览次数:21079 次

七、最好用哪种方法提取记录集?
到目前为止我们一直通过创建Recordset对象提取记录集,但是ADO也提供了间接的记录集提取方法。下面的测试比较ADO__03.ASP和直接从Connection对象创建记录集(CONN_01.ASP)这两种方法:

Set objConn = Server.CreateObject("ADODB.Connection")
objConn.Open Application("Conn")

Set objRS = objConn.Execute(Application("SQL"))

可以看到页面开销略有增加,单个记录的显示时间没有变化。

下面我们再来看看从Command对象直接创建记录集对象(CMD__02.ASP):
Set objCmd = Server.CreateObject("ADODB.Command")
objCmd.ActiveConnection = Application("Conn")
objCmd.CommandText = Application("SQL")

Set objRS = objCmd.Execute

同样,页面开销也略有增加,而单个记录的显示时间没有本质的变化。后面这两种方法在性能上的差异很小,但我们还有一个重要的问题需要考虑。

通过Recordset类创建记录集时,我们能够以最大的灵活性控制记录集的处理方式。既然后面两种方法未能有压倒性的性能表现,我们主要还是考虑默认返回的游标类型和记录锁定方式,对于某些场合来说默认值并不一定是最理想的。

因此,除非由于特殊的原因需要选择后面两种方法,否则我们建议考虑下面的规则:

通过ADODB.Recordset类实例化记录集,以获得最好的性能和灵活性。