rs.open的参数一共有五个
分别是
Source,ActiveConnection,CursorType,LockType,Options
前两个不用多说,后三个说明一下
CursorType:记录集的游标类型,即返回的记录集中指针(游标)是如何移动的,一共有四个值
=======================================================
AdOpenForwardOnly (0) (默认值)打开仅向前类型游标。
AdOpenKeyset (1) 打开键集类型游标。
AdOpenDynamic (2) 打开动态类型游标。
AdOpenStatic (3) 打开静态类型游标。
========================================================
LockType:记录集的锁定(并发)类型,也就是记录集是否允许更新且如何更新,一共四个值
========================================================
AdLockReadOnly (0)(默认值)只读 — 不能改变数据。
AdLockPessimistic (1) 保守式锁定(逐个) — 提供者完成确保成功编辑记录所需的工作,通常通过在编辑时立即锁定数据源的记录。
AdLockOptimistic (2) 开放式锁定(逐个) — 提供者使用开放式锁定,只在调用Update 方法时才锁定记录。
AdLockBatchOptimistic (3) 开放式批更新—用于批更新模式(与立即更新模式相对)。
========================================================
Options:指示提供者如何计算 Source 参数,即第一个source参数是sql语句还是表还是存储过程名等,一共9个值
========================================================
adCmdText 指示提供者应该将 Source 作为命令的文本定义来计算。
adCmdTable 指示 ADO 生成 SQL 查询以便从在 Source 中命名的表中返回所有行。
adCmdTableDirect 指示提供者更改从在 Source 中命名的表中返回所有行。
adCmdStoredProc 指示提供者应该将 Source 视为存储过程。
adCmdUnknown 指示 Source 参数中的命令类型为未知。
adCmdFile 指示应从在 Source 中命名的文件中恢复保留(保存的)Recordset。
adAsyncExecute 指示应异步执行 Source。
adAsyncFetch 指示在提取 Initial Fetch Size 属性中指定的初始数量后,应该异步提取所有剩余的行。如果所需的行尚未提取,主要的线程将被堵塞直到行重新可用。
adAsyncFetchNonBlocking 指示主要线程在提取期间从未堵塞。如果所请求的行尚未提取,当前行自动移到文件末尾。
========================================================
平常大家都会用adOpenKeySet,AdLockPessimistic或者adOpenKeySet,AdLockBatchOptimistic
但是大多数情况下,其实获得的记录集并不需要更新,而且也不需要指针向前移动,所以不要一味的使用,根据获得记录集需要使用的情况,分别设置CursorType值和LockType值,比如记录集只是用来显示列表,那么就用
AdOpenForwardOnly,AdLockReadOnly
这样获取记录集的速度是最快的
另外希望大家多学习ADO的知识
[此贴子已经被作者于2006-8-15 16:32:13编辑过]