ADO中游标类型及常量说明
Saturday, 10. June 2006, 08:49:51
转摘自Microsoft的Ado手册,关于游标定义参考adoint.h
(也可以参看Microsoft Office 应用程序脚本编写提示和技巧 2006.6.23)
(以前老是弄不清楚游标的字符常量和数字常量的关系,今天问了姐夫,从Visual Studio中的adoint.h找到该定义)
在 ADO 中定义了四种不同的游标类型:
动态游标 — 用于查看其他用户所作的添加、更改和删除,并用于不依赖书签的 Recordset 中各种类型的移动。如果提供者支持,可使用书签。常量adOpenDynamic = 2。
键集游标 — 其行为类似动态游标,不同的只是禁止查看其他用户添加的记录,并禁止访问其他用户删除的记录,其他用户所作的数据更改将依然可见。它始终支持书签,因此允许 Recordset 中各种类型的移动。常量adOpenKeyset = 1。
静态游标 — 提供记录集合的静态副本以查找数据或生成报告。它始终支持书签,因此允许 Recordset 中各种类型的移动。其他用户所作的添加、更改或删除将不可见。这是打开客户端 (ADOR) Recordset 对象时唯一允许使用的游标类型。常量adOpenStatic = 3。
仅向前游标 — 除仅允许在记录中向前滚动之外,其行为类似静态游标。这样,当需要在 Recordset 中单程移动时就可提高性能。常量adOpenForwardOnly = 0。
LockType 属性
指示编辑过程中对记录使用的锁定类型。
设置和返回值
设置或返回以下某个 LockTypeEnum 的值。
常量 说明
adLockReadOnly=1 默认值,只读。无法更改数据。
adLockPessimistic=2 保守式记录锁定(逐条)。提供者执行必要的操作确保成功编辑记录,通常采用编辑时立即锁定数据源的记录的方式。
adLockOptimistic=3 开放式记录锁定(逐条)。提供者使用开放式锁定,只在调用 Update 方法时锁定记录。
adLockBatchOptimistic=4 开放式批更新。用于与立即更新模式相反的批更新模式。
说明
打开 Recordset 前设置 LockType 属性可指定打开时提供者应该使用的锁定类型。读取该属性可返回在打开的 Recordset 对象上正在使用的锁定类型。Recordset 关闭时 LockType 属性为读/写,打开时该属性为只读。
提供者可能不支持所有的锁定类型。如果某提供者不支持所需的 LockType 设置,则将替换为其他类型的锁定。
(也可以参看Microsoft Office 应用程序脚本编写提示和技巧 2006.6.23)
(以前老是弄不清楚游标的字符常量和数字常量的关系,今天问了姐夫,从Visual Studio中的adoint.h找到该定义)
在 ADO 中定义了四种不同的游标类型:
动态游标 — 用于查看其他用户所作的添加、更改和删除,并用于不依赖书签的 Recordset 中各种类型的移动。如果提供者支持,可使用书签。常量adOpenDynamic = 2。
键集游标 — 其行为类似动态游标,不同的只是禁止查看其他用户添加的记录,并禁止访问其他用户删除的记录,其他用户所作的数据更改将依然可见。它始终支持书签,因此允许 Recordset 中各种类型的移动。常量adOpenKeyset = 1。
静态游标 — 提供记录集合的静态副本以查找数据或生成报告。它始终支持书签,因此允许 Recordset 中各种类型的移动。其他用户所作的添加、更改或删除将不可见。这是打开客户端 (ADOR) Recordset 对象时唯一允许使用的游标类型。常量adOpenStatic = 3。
仅向前游标 — 除仅允许在记录中向前滚动之外,其行为类似静态游标。这样,当需要在 Recordset 中单程移动时就可提高性能。常量adOpenForwardOnly = 0。
LockType 属性
指示编辑过程中对记录使用的锁定类型。
设置和返回值
设置或返回以下某个 LockTypeEnum 的值。
常量 说明
adLockReadOnly=1 默认值,只读。无法更改数据。
adLockPessimistic=2 保守式记录锁定(逐条)。提供者执行必要的操作确保成功编辑记录,通常采用编辑时立即锁定数据源的记录的方式。
adLockOptimistic=3 开放式记录锁定(逐条)。提供者使用开放式锁定,只在调用 Update 方法时锁定记录。
adLockBatchOptimistic=4 开放式批更新。用于与立即更新模式相反的批更新模式。
说明
打开 Recordset 前设置 LockType 属性可指定打开时提供者应该使用的锁定类型。读取该属性可返回在打开的 Recordset 对象上正在使用的锁定类型。Recordset 关闭时 LockType 属性为读/写,打开时该属性为只读。
提供者可能不支持所有的锁定类型。如果某提供者不支持所需的 LockType 设置,则将替换为其他类型的锁定。







