ASP Recordset分页出现负数的解决方法 - ASP教程
对于Recordset分页时出现负数的现象,相信会有很多人遇到过这个问题,有 时百度、GOOGLE也不得其解,现在由我来总结一下。
出现负数,主要和游标类型有关系。(为举例方便,假设已经有一个conn.asp 链接数据库的文件并且已经include)现在举一个例子,代码如下:
根据上面的代码,RecordSet对象直接由代码:Set rs=conn.execute(sql), 使用该句后,RecordSet对象默认的游标为0,即游标只能向前滚动,锁定类型为0 ,表示只读锁定,不能更新RecordSet对象。 所以,对于分页时如果出现负数,则检查RecordSet对象是否写为以上形式, 要写成:
以上表示游标为1,可向前向后移动;锁定类型为3,可批量更新多条记录。 根据上述方法做基本上不再会有问题,但为保险,根据RecordSet分页的原理 是根据读取所有记录后获取记录数,所以先让游标滚动一圈,在级 rs.pagesize=10 后面加上以下两句: rs.movelast '游标移至最后 rs.movefirst '游标移到最前 已知RecordSet的分页原理为先把整个数据库里面的记录读出后才能获取 rs.Recordcount(记录总数)的值。这种分页方法比较简单,但是有一个致命的 坏处,当数据库里记录数有很多条时,根据其分页原理,这样就会占用很高的系 统资源,非常浪费,建议在实际编程中不使用该方法。现在给大家一个思路,可 以在SQL查询语句里做分页处理,每次读取固定的记录数,具体如下: 从数据库表中的第M条记录开始取N条记录,利用Top关键字:注意如果Select 语句中既有top,又有order by,则是从排序好的结果集中选择:
用以上SQL语句进行分页,错误会比较少,最重要得是效率比较高。 (编辑:滁州站长网) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |