asp mysql rs.recordcount_asp中rs.recordcount 返回值总是为-1的解决方法

我们在利用ASP程序进行分页的时候,特别是在用到统计记录总数的属性rs.recordcount时,有时结果会出现-1,为什么会出现这种情呢?看看下面两种情况:

这样就没问题rs.open sqlstr,conn,3,2

这样就有问题rs.open sqlstr,conn,1,2

为什么呢?因为是rs的游标类型问题

因为conn后第一个数字是1表示指针只能往前,3表示自由指针

使用RecordCount属性可确定Recordset对象中记录的数目。ADO无法确定记录数时,或者如果提供者或游标类型不支持RecordCount,则该属性返回–1。读已关闭的Recordset上的RecordCount属性将产生错误。

如果Recordset对象支持近似定位或书签(即Supports(adApproxPosition)或Supports(adBookmark)各自返回True),不管是否完全填充该值,该值将为Recordset中记录的精确数目。如果Recordset对象不支持近似定位,该属性可能由于必须对所有记录进行检索和计数以返回精确RecordCount值而严重消耗资源。

Recordset对象的游标类型会影响是否能够确定记录的数目。对仅向前游标,RecordCount属性将返回-1,对静态或键集游标返回实际计数,对动态游标取决于数据源返回-1或实际计数。

文章来自: ASP技术网站(www.aspjs.net) 详文参考:http://www.aspjs.net/aspjs1html/ASPjiaocheng/ASPjishuziliao/469.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值