ASP开发中关于RecordCount只返回-1的问题解接方式!

来源:互联网 发布:优化和推广的区别 编辑:程序博客网 时间:2024/04/27 05:05
原作者:最爱白菜  原作:ASP开发中关于RecordCount只返回-1的问题解接方式!

到WEB版,经常见有人问,为什么我的RecordCount总是只返回-1的问题?

典型问题

是否可以告诉我下面的代码什么地方出错了?   
< %

Set objConn = Server.CreateObject("ADODB.Connection")
Set objRst = Server.CreateObject("ADODB.Recordset")

objConn.Open("DRIVER={Microsoft Access Driver (*.mdb)}; DBQ=" & Server.Mappath("seannewelldbsean.mdb"))

strSQL = "SELECT * FROM people"

objRst.Open strSQL, objConn? '<<========这里是关键

Response.write( "< P >" & strSQL & "< /P >" )
Response.write("< H2 >There are " & objRst.RecordCount &
" People in the database< /H2 >")

If objRst.RecordCount > 0 Then
objRst.MoveFirst
Do While Not objRst.EOF
Response.write( "Name = " & objRst.fields(0) )
objRst.MoveNext
Loop
else
Response.write( "It's EMPTY!" )
End If

objRst.Close
Set objRst = Nothing
objConn.Close
Set objConn = Nothing
% >

答案:

在低版本的MDAC中RecordCount属性返回-1。请在你的服务器上把MDAC文件更新到最新的版本,最新的MDAC文件可以在www.microsoft.com/data找到。 如果Web服务器由ISP管理而你又无权配置它,无法升级MDAC文件,那么必须修改代码。

原来使用下面的代码检查记录集中是否有记录:   
If objRst.RecordCount > 0 Then ...


   请改用下面的代码:   
If objRst.BOF and objRst.EOF Then
' 记录集为空
Else
Do While not objRst.EOF
' 处理记录集
objRst.MoveNext
Loop
End If

?新西兰的Daryl Egarr说:

   可以看出,读者提问中的代码并没有错误。问题在于“在低版本的MDAC中RecordCount属性返回-1”,这一判断本身并没有错误,然而从提问内容来看作者不应该作出这种假定,因为原问题中没有任何一行代码意味着使用了低版本的MDAC。

   作者考虑问题的方向不对,问题的要点在于并非所有的游标类型都支持所有的属性和方法(不管采用哪种数据库系统)。问题中代码出现错误的真正原因在于使用默认的CursorLocation时:   
Recordset.CursorLocation = adUseServer

   RecordCount属性只有在记录集的CursorType为1或者3(即adOpenKeyset,adOpenStatic)时才是可用的。出现错误的代码没有指定CursorType,也就是使用了0类型的游标(即adOpenForwardOnly,这是速度最快的游标类型),此时对RecordCount的引用将一直返回0。

   解决问题的方法很简单,只要把原来代码中的:   
objRst.Open strSQL, objConn

   改成:   
objRst.Open strSQL, objConn ,1

********************************************************

最后另外附上:

连接数据库时的游标类型和加锁类型,分述如下:

游标类型

Const?adOpenForwardOnly?=?0
前向游标,为缺省游标,提供最快的运行性能。用它打开recordset,从对至尾顺序取得所有结果。它不支持向后滚动,只允许在结果间单向移动。

Const?adOpenKeyset?=?1
静态游标,反映第一次打开游标时表中数据的状态,游标无法查明底层表中的数据行是否更新过、删除过或添加了新的数据。不过与只能前移的洲标不同,静态游标可以在结果间前后滚动。

Const?adOpenDynamic?=?2
键盘驱动的游标,可以查询表中底层数据行的某些变化,但不是全部。它特别是可以准确反映数据是否更新过。但它不能查明其它用户是否曾删除过数据行(删除掉的数据行在recordset中会留下空洞)。键盘驱动的游标支持在结果间前后滚动。

Const?adOpenStatic?=?3??????????????????????
动态游标,是最丰富的游标类型。游标打开时可以查询其他用户对表的任何改动,而且支持滚动。

加锁类型
Const?adLockReadOnly?=?1
缺省的上锁类型,只读方式上锁允许多个用户同时读取同样的数据,但不能改变数据。

Const?adLockPessimistic?=?2
以悲观上锁方式打开数据对象。该方式假定在你编辑记录时会有其它用户访问数据。此时一旦你开始编辑记录,其它用户就不能访问该数据。

Const?adLockOptimistic?=?3
以乐观上锁方式打开数据对象。该方式假定在你编辑记录时不会有其它用户访问数据。在完成改变之前,其它用户不能访问该记录。

Const?adLockBatchOptimistic?=?4
执行多行批处理更新时使用这种类型

最后,打开一个记录集时,你可以指定一个Options参数。Options参数标明用来打开记录集的命令字符串的类型。告诉ADO被执行的字符串内容的有关信息有助于高效地执行该命令字符串。

你可以使用下面的常量作为Options参数:

adCMDTable。被执行的字符串包含一个表的名字。
adCMDText。被执行的字符串包含一个命令文本。
adCMDStoredProc。被执行的字符串包含一个存储过程名。
adCMDUnknown。不指定字符串的内容。(这是缺省值。)

原创粉丝点击