Extensible Storage Engine

较新的Windows SDK中提供了一种非关系型嵌入式数据库引擎ESENT(Extensible Storage Engine),它适用于那些需要高性能、较小存储空间支出的应用。ESENT已应用于AD、Windows Desktop Search、Windows Live Mail多个微软产品中。它有以下基本特点:

1、事务支持、延迟提交、健壮的恢复、备份。

2、记录级的锁。

3、高并发的数据库访问。

4、灵活的元数据定义(表、列、索引)。

5、支持整形、浮点型、字符型、二进制列的索引。

6、自定义列最大支持2GB、数据库最大支持16TB。

如果使用natvie C++,只需要include esent.h,链接esent.lib。

如果使用托管API,可以从 http://managedesent.codeplex.com/ 下载最新的版本。

Esent.Interop.dll提供了Platform Invoke的封装、Esent.Collections.dll则包含了基于ESENT的集合类型、并实现自定义的部分LINQ支持。

在使用托管API时需要注意以下几点:

1、调用JetOpenDatabase函数之前需要先调用JetAttachDatabase。

2、JetMakeKey的data参数需要非托管的字节数组。

3、查询数据先调用JetMakeKey,再调用Seek、TrySeek。

4、默认游标是从First开始,调用TryMove时需要先访问数据记录。比如:

1 do
2 
3     Console.WriteLine(Api.RetrieveColumnAsString(sesid, tableid, columnid, Encoding.Unicode));
4 
5 while (Api.TryMove(sesid, tableid, JET_Move.Next, MoveGrbit.None));

关于ESENT的更详细SDK,可以参考http://msdn.microsoft.com/en-us/library/gg269259(v=exchg.10).aspx。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值