文章探索:   分类:    关键字:  
  + 栏目导航
  + 相关文章
asp中有关字符编码转换的几个函数
绝妙的asp生成静态页面html函数
Asp计算页面执行时间
一个简单的用存储过程分页
将asp页面转换成htm页面
ASP网站漏洞解析及黑客入侵防范方法
URL编码与SQL注入
几种常用排序算法(asp)
ASP调用带参数存储过程的几种方式
实用的ASP连接数据库的函数
ASP如何获取真实IP地址
ASP中怎么实现SQL数据库备份、恢复
判断Cookies是否处于开启状态
怎样才能将服务器端文件夹下的文件,..
几行Asp代码实现防止表单重复提交
用ASP设计网站在线人数统计程序
asp论坛在线人数统计研究
如何用ASP远程在数据库中创建Table
用ASP调用SQL Server的视图和存储过程
Asp与XML的关系
ASP读取EXCEL
在ASP中使用Oracle数据库技巧
一个通过web.Mail发送邮件的类
几种打开记录集方式的比较
购物车范例(购物车页面 )
如何使用FSO搜索硬盘文件
GB码和BIG5码的互换技术
用ASP开发WEB日期选择器
一个投票系统的源程序(coveryourasp.c..
列出服务器上的打印机


技术教程 -> ASP教程 ->  
几种打开记录集方式的比较
来源:csdn   人气:1566   录入时间:2007-11-8
    几种打开记录集方式的比较
   
   先定义conn.asp
   <%
    dim objConn
    dim strConn
    strConn = "Provider=Microsoft.Jet.OLEDB.4.0;Data Source=" & chr(34) & Server.MapPath("data.mdb") & chr(34)
    set objConn = server.createobject("adodb.connection")
    objConn.open strConn
   %>
   
   再来看一看几种不同打开记录集(recordset)的方式
   
   方式1、
    dim sql
    dim objRs
   
    sql = "select * from table1"
    set objRs = objConn.execute( sql )
   
   这种方式通过执行sql,返回后得到记录集,比较简单地得到经过筛选过的记录集,
   但是通过这种方式得到的记录集,不能进行分页显示。
   
   文件text1.asp
   
   <%@LANGUAGE="VBSCRIPT" CODEPAGE="936"%>
   <!-- #include file="conn.asp" -->
   
   <%
    dim sql
    dim objRs
   
    sql = "select * from table1"
    set objRs = objConn.execute( sql )
   
    objRs.pagesize = 5
    objRs.absolutepage = 1
   %>
   
   请求该页面得到的结果是:
   
   ------------------------------------------------------------
   错误类型:
   ADODB.Recordset (0x800A0CB3)
   当前记录集不支持书签。这可能是提供程序或选定的游标类型的限制。
   /msg/test1.asp, 第 12 行
   
   
   浏览器类型:
   Mozilla/4.0 (compatible; MSIE 6.0; Windows NT 5.1; SV1; .NET CLR 1.1.4322)
   
   网页:
   GET /msg/test1.asp
   
   时间:
   2005年9月21日, 19:58:01
   ------------------------------------------------------------
   
   方式2、
    dim objRs
    set objRs = Server.CreateObject( "ADODB.Recordset" )
    objRs.open "table1" , objConn , 1 , 2
   
   用这种方式打开的记录可以进行分页显示。
   
   <%
    dim objRs
   
    set objRs = Server.CreateObject( "ADODB.Recordset" )
    objRs.open "table1" , objConn , 1 , 2
   
    objRs.pagesize = 5
    objRs.absolutepage = 1
   %>
   
   用这个试试,哈哈,顺利运行。
   
   但这种方式打开的记录集不能排序
   
   文件test2.asp
   
   <%@LANGUAGE="VBSCRIPT" CODEPAGE="936"%>
   <!-- #include file="conn.asp" -->
   <%
    dim objRs
   
    set objRs = Server.CreateObject( "ADODB.Recordset" )
    objRs.open "table1" , objConn , 1 , 2
   
    objRs.sort = "field1"
   %>
   
   请求该页面得到的结果是:
   
   ------------------------------------------------------------
   错误类型:
   ADODB.Recordset (0x800A0CB3)
   当前提供程序不支持排序或过滤所必需的界面。
   /msg/test2.asp, 第 17 行
   
   
   浏览器类型:
   Mozilla/4.0 (compatible; MSIE 6.0; Windows NT 5.1; SV1; .NET CLR 1.1.4322)
   
   网页:
   GET /msg/test2.asp
   
   时间:
   2005年9月21日, 20:17:32
   ------------------------------------------------------------
   
   怎办呢?
   
   哈,这样就行啦。
   
   <%@LANGUAGE="VBSCRIPT" CODEPAGE="936"%>
   <!-- #include file="conn.asp" -->
   <%
    dim objRs
   
    set objRs = Server.CreateObject( "ADODB.Recordset" )
    objRs.CursorLocation = 3
    objRs.open "table1" , objConn , 1 , 2
   
    objRs.sort = "field1 desc"
   %>
   
   总结一下:
    1、方式1,可以通过sql语句,方便地筛选你想要的记录。
    2、方式2,功能比较强大,但比较复杂。
    这种方式还有更有用的用法。详见其它参考资料。
   
   
   




Copyright(C)2007-2021 广州市佳沛数码科技有限公司 版权所有
公司地址: 广州市荔湾区东漖北路560号511室
电话:020-81803473 传真:020-81544987