首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >存在于ESENT中

存在于ESENT中
EN

Stack Overflow用户
提问于 2014-07-04 20:48:02
回答 2查看 403关注 0票数 1

我正在尝试查询表中是否存在记录。现在,一种显而易见的方法就是寻找记录:

代码语言:javascript
复制
// Create correct keys for index with Api.MakeKey
Api.JetSeek(sessionId, tableId, SeekGrbit.SeekEQ);

但是,此操作会将光标设置为找到的记录(成功时),这是我不想做的。我想我可以以某种方式快速地存储当前的记录编号,然后将其设置回来,但也许有更好的解决方案?我在api中找不到正确的方法。

那么,是否可以执行Exists,也就是说,查找只是为了检查记录是否存在?

顺便说一下,我使用的是带有ESENT1.9.0管理接口的.NET 4.0。

EN

回答 2

Stack Overflow用户

发布于 2014-07-07 16:45:40

首先,使用JetGetRecordPosition方法获取光标的当前位置

代码语言:javascript
复制
public static void JetGetRecordPosition(
    JET_SESID sesid,
    JET_TABLEID tableid,
    out JET_RECPOS recpos
)

然后检查记录是否像您所做的那样存在

代码语言:javascript
复制
Api.JetSeek(sessionId, tableId, SeekGrbit.SeekEQ);

或者使用布尔方法TrySeek,如果找到匹配条件的记录,则返回true。

代码语言:javascript
复制
public static bool TrySeek(
    JET_SESID sesid,
    JET_TABLEID tableid,
    SeekGrbit grbit
)

然后你需要将光标设置在前一个位置,为此使用Api.JetGotoPosition方法和你从第一个方法中得到的recpos。

代码语言:javascript
复制
public static void JetGotoPosition(
    JET_SESID sesid,
    JET_TABLEID tableid,
    JET_RECPOS recpos
)

希望能有所帮助。

票数 1
EN

Stack Overflow用户

发布于 2016-07-15 00:40:23

另一种技术是使用JetDupCursor()方法创建独立于当前JET_TABLEID的新JET_TABLEID。这样,如果找到行,TrySeek()方法将不会更改原始游标的位置

https://msdn.microsoft.com/en-us/library/microsoft.isam.esent.interop.api.jetdupcursor%28v=exchg.10%29.aspx?f=255&MSPPError=-2147217396

票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/24574723

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档