为何我的recordcount总返回-1

visual 2000-03-13 09:00:00
请问:

我在我的ASP中使用了SQL server 7.0 代码如下:

Set Conn=Server.CreateObject("ADODB.Connection")
connstr="Provider=SQLOLEDB.1;Persist Security Info=False;User ID=sa;Initial Catalog=books;Data Source=kingnet"
Conn.Open connstr
Set Conn=Server.CreateObject("ADODB.Connection")
Conn.Open connstr
set cm=server.CreateObject("ADODB.command")
set cm.ActiveConnection=conn
cm.Prepared=True
set rs=server.CreateObject("adodb.recordset")
strsql= "select * from reader "

rs.CursorType =adOpenStatic
rs.Open strsql,conn

Response.Write "the 总记录: <br>"
Response.Write rs.RecordCount

不知为何,Recoedcount总为-1,但是记录集却取得极为正确
使用
do until rs.eof
response.write rs(" ...
.
.
.
rs.movenext
loop
均可正确显示,唯独recordcount 为-1

我还使用过cm.execute(l_count),得到的l_count也为-1,其他一切正确。

我的后台数据库的reader表有主键。
这个问题我在Acces中也遇到过。
现在我只好先用 select count(...) as num ...先得到记录数。然后再继续真正的SQL语句。
我在VB中使用类似代码,正确!

不知ASP到底支不支持Recordcount。如果您实现过recordcount in asp。还请您明示。最好能找出我的问题所在。

请各位帮忙!
谢谢.
...全文
189 5 打赏 收藏 转发到动态 举报
写回复
用AI写文章
5 条回复
切换为时间正序
请发表友善的回复…
发表回复
l_cheng 2000-03-14
  • 打赏
  • 举报
回复
当未说明cursor类型时,cursor缺省为1,这时不支持recordcount属性;你必须显式指定
cursor类型为3,只有它才支持recordcount属性
ypjiang 2000-03-14
  • 打赏
  • 举报
回复
it need that the cursor type of the opening recordset is 1 or 3
King 2000-03-13
  • 打赏
  • 举报
回复
ZDG说的对,我刚试完,如果不以rs.Open strsql,conn,1,1的方式打开的话,MOVELAST也没有用。
david 2000-03-13
  • 打赏
  • 举报
回复
首先要MOVEFIRST,然后再MOVELAST,大概就可得到RECORCOUNT.
zdg 2000-03-13
  • 打赏
  • 举报
回复
rs.Open strsql,conn
改成
rs.Open strsql,conn,1,1
就可以了...

28,390

社区成员

发帖
与我相关
我的任务
社区描述
ASP即Active Server Pages,是Microsoft公司开发的服务器端脚本环境。
社区管理员
  • ASP
  • 无·法
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
暂无公告

试试用AI创作助手写篇文章吧