JetDupSession 函数

适用于: Windows |Windows Server

JetDupSession 函数

JetDupSession 函数启动会话,并初始化并返回 ESE 会话句柄, (JET_SESID) 。 会话控制对数据库的所有访问,并用于控制事务的范围。 会话可用于开始、提交或中止事务。 会话还用于附加、创建或打开数据库。 会话用作所有 DDL 和 DML 操作的上下文。 若要增加对数据库的并发和并行访问,可以启动多个会话。

注意 此 API 将以各种方式充当对传入的会话实例调用的 JetBeginSession 。 不建议使用此函数, 首选 JetBeginSession

    JET_ERR JET_API JetDupSession(
      __in          JET_SESID sesid,
      __out         JET_SESID* psesid
    );

parameters

sesid

要用作复制或启动会话的源的会话。

psesid

指向会话处理在成功返回时初始化的变量的指针。

返回值

此函数返回具有以下返回代码之一 的JET_ERR 数据类型。 有关可能的 ESE 错误的详细信息,请参阅 可扩展存储引擎错误错误处理参数

返回代码

说明

JET_errSuccess

操作已成功完成。

JET_errClientRequestToStopJetService

无法完成操作,因为由于调用 JetStopService,与会话关联的实例上的所有活动都已停止。

JET_errInstanceUnavailable

无法完成该操作,因为与会话关联的实例遇到一个致命错误,该错误要求撤销对所有数据的访问以保护该数据的完整性。

此错误仅由 Windows XP 和更高版本返回。

JET_errInvalidParameter

提供的其中一个参数包含意外值或包含一个值,当与另一个参数的值组合时,该值没有意义。

JET_errNotInitialized

无法完成操作,因为尚未初始化与会话关联的实例。

JET_errOutOfMemory

操作失败,因为无法分配内存。

JET_errOutOfSessions

引擎将允许客户端启动的会话数有限。 可以使用具有 JET_paramMaxSessions 常量的 JetSetSystemParameter 更改此值。 默认会话数为 16。 有关JET_paramMaxSessions的详细信息,请参阅系统参数

JET_errRestoreInProgress

无法完成操作,因为正在与会话关联的实例上执行还原操作。

JET_errTermInProgress

无法完成操作,因为与会话关联的实例正在关闭。

成功后,会话句柄将初始化,并可用于数据库操作。

失败时,没有可用的会话,或者无法初始化新会话。

要求

要求

客户端

需要 Windows Vista、Windows XP 或 Windows 2000 Professional。

服务器

需要 Windows Server 2008、Windows Server 2003 或 Windows 2000 Server。

标头

在 Esent.h 中声明。

Library

使用 ESENT.lib。

DLL

需要ESENT.dll。

另请参阅

JET_SESID
JetBeginSession
JetSetSystemParameter
JetStopService
系统参数