MDB_env 为一个结构体,Opaque structure for a database environment.

MDB_txn :Opaque structure for a transaction handle.

typedef unsigned int MDB_dbi, A handle for an individual database in the DB environment.

struct MDB_val  :Generic structure used for passing keys and data in and out of the database.

它包含:size_t mv_size, void* mv_data;

structure MDB_cursor: Opaque structure for navigating through a database.

函数 int mdb_env_create(MDB_env** env)

它的作用就是创建一个LMDB的环境handle,就是指向一个分配了内存的地址啦,这个函数会为MDB_env结构体分配一个内存。它我们使用handle  的时候,首先要用mdb_env_open()函数打开,最后也要调用mdb_env_close()函数释放掉内存并discard handle。

参数:[out] env,The address where the new handle will be stored。

返回:如果错误,返回一个非零的值,如果正确,返回零;

函数 :mdb_env_open()

int mdb_env_open  ( MDB_env *  env,
const char * path,
unsigned int flags,
mdb_mode_t mode
)

它的作用是:打开一个环境handle。

注:如果函数失败,我们要调用 mdb_env_close() 来丢弃  MDB_env handle.

参数说明:

[in] env :就是我们的环境handle。

[in] path :数据的路径。注意:它必须存在,并且可写;

[in] flags: 对于环境的一些特别的选项,它必须被设为0 或着把不同的选项 or在一起,

常见的flag:http://104.237.133.194/doc/ group__mdb.html#ga32a193c6bf4d7d5c5d579e71f22e9340

[in] mode:对于linux来说 ,就是这个操作的对于文件权限(如:0644),windows忽略;

返回值:如果错误,返回一个非零的值,如果正确,返回零;

函数 :mdb_env_close ()

void mdb_env_close ( MDB_env * env)

作用:Close the environment and release the memory map.

函数: int mdb_env_set_mapsize()

int mdb_env_set_mapsize  ( MDB_env *  env,
size_t size
)

作用:设置环境的memory map 的大小;注意:默认大小 为:10485760 bytes,该函数用在mdb_env_create()之后,且mdb_env_open()之前,当然,在后面它也可能被调用的;

返回值:如果错误,返回一个非零的值,如果正确,返回零;

函数:int mdb_txn_begin()

int mdb_txn_begin  ( MDB_env *     env,
MDB_txn * parent,
unsigned int flags,
MDB_txn ** txn
)

作用:Create a transaction for use with the environment.

参数:[in] env:An environment handle returned by mdb_env_create()

[in] parent:可以为空,即NULL,如果不是空的话,the new transaction will be a nested transaction。

[in] flags: 指对于操作来说一些特别的选项,可以为0或着其它:如MDB_RDONLY,表示:它不会执行任何写操作;

[in] txn  ,Address where the new MDB_txn handle will be stored .

返回值:如果错误,返回一个非零的值,如果正确,返回零;

另外:The transaction handle may be discarded using mdb_txn_abort() or mdb_txn_commit().

函数:mdb_dbi_open()

int mdb_dbi_open  ( MDB_txn *  txn,
const char * name,
unsigned int flags,
MDB_dbi * dbi
)

作用:在环境里打开一个database;

注意:database handle denotes the name and parameters of a database, independently of whether such a database exists.The database handle may be discarded by calling mdb_dbi_close().

参数:

[in] txn :A transaction 的handle;

[in]  name:打开的database的名字,If only a single database is needed in the environment, this value may be NULL.

[in]  flags:Special options for this database. 可以为0或着其它选项

[out] dbi :Address where the new MDB_dbi handle will be store;

返回值:如果错误,返回一个非零的值,如果正确,返回零;

函数:int mdb_put()

int mdb_put  ( MDB_txn *  txn,
MDB_dbi dbi,
MDB_val * key,
MDB_val * data,
unsigned int flags
)

作用:store items into a datagase,也就是说,把key/data pairs存放到database里面。

注意:当键值有相同的时候,The default behavior is to enter the new key/data pair, replacing any previously existing

key if duplicates are disallowed, or adding a duplicate data item if duplicates are allowed 。

参数:

[in] txn: A transaction handle returned by mdb_txn_begin() 
[in] dbi :A database handle returned by mdb_dbi_open() 
[in] key :The key to store in the database 
[in,out] data: The data to store 
[in] flags Special options for this operation. This parameter must be set to 0 or by bitwise OR'ing together one or more of the values described here.

返回值:如果错误,返回一个非零的值,如果正确,返回零;

函数:int mdb_txn_commit()

int mdb_txn_commit  ( MDB_txn *  txn )

作用:提交所有的操作:Commit all the operations of a transaction into the database.

注意:提交完以后,The transaction handle is freed. It and its cursors must not be used again after this call, except with mdb_cursor_renew().

参数:[in] txn:即我们要提交的那个transaction的handle;

返回值:如果错误,返回一个非零的值,如果正确,返回零;

函数:int mdb_cursor_open ()

int mdb_cursor_open  ( MDB_txn *  txn,
MDB_dbi dbi,
MDB_cursor ** cursor
)

作用:创建一个cursor的handle。

备注:A cursor is associated with a specific transaction and database。

参数:

[in] txn A transaction handle returned by mdb_txn_begin()
[in] dbi A database handle returned by mdb_dbi_open()
[out] cursor Address where the new MDB_cursor handle will be stored

返回值:如果错误,返回一个非零的值,如果正确,返回零;

函数:mdb_cursor_get()

int mdb_cursor_get  ( MDB_cursor *  cursor,
MDB_val * key,
MDB_val * data,
MDB_cursor_op op
)

功能:通过cursor读取数据

参数:

[in] cursor: A cursor handle returned by mdb_cursor_open()
[in,out] key: The key for a retrieved item
[in,out] data: The data of a retrieved item
[in] op: A cursor operation MDB_cursor_op

其中:enum MDB_cursor_op,它枚举了许多Cursor Get 的操作,如下所示:

MDB_FIRST
Position at first key/data item MDB_FIRST_DUP
Position at first data item of current key. Only for MDB_DUPSORT MDB_GET_BOTH
Position at key/data pair. Only for MDB_DUPSORT MDB_GET_BOTH_RANGE
position at key, nearest data. Only for MDB_DUPSORT MDB_GET_CURRENT
Return key/data at current cursor position MDB_GET_MULTIPLE
Return key and up to a page of duplicate data items from current cursor position. Move cursor to prepare for MDB_NEXT_MULTIPLE. Only for MDB_DUPFIXED MDB_LAST
Position at last key/data item MDB_LAST_DUP
Position at last data item of current key. Only for MDB_DUPSORT MDB_NEXT
Position at next data item MDB_NEXT_DUP
Position at next data item of current key. Only for MDB_DUPSORT MDB_NEXT_MULTIPLE
Return key and up to a page of duplicate data items from next cursor position. Move cursor to prepare for MDB_NEXT_MULTIPLE. Only for MDB_DUPFIXED MDB_NEXT_NODUP
Position at first data item of next key MDB_PREV
Position at previous data item MDB_PREV_DUP
Position at previous data item of current key. Only for MDB_DUPSORT MDB_PREV_NODUP
Position at last data item of previous key MDB_SET
Position at specified key MDB_SET_KEY
Position at specified key, return key + data MDB_SET_RANGE
Position at first key greater than or equal to specified key.

先写到这里吧。。

看的时候,可以结合一个例子:http://blog.csdn.net/u012235274/article/details/51899598

还有很多:http://104.237.133.194/doc/index.html

lmdb存储的一些库相关函数的更多相关文章

  1. C语言操作WINDOWS系统存储区数字证书相关函数详解及实例

     C语言操作WINDOWS系统存储区数字证书相关函数详解及实例 以下代码使用C++实现遍历存储区证书及使用UI选择一个证书 --使用CertOpenSystemStore打开证书存储区. --在循环中 ...

  2. python 存储引擎 mysql(库,表, 行) 单表多表操作 (foreign key) sql_mode pymysql模块讲解

    ##################总结############### mysql 常用数据类型 整型:tinyint  int(42亿条左右)  bigint 小数:float double dec ...

  3. python开发mysql:mysql安装(windows)&密码找回&存储引擎简介&库表的增删改查

    一,mysql安装 下载地址 https://dev.mysql.com/downloads/file/?id=471342 解压后,将目录C:\mysql-5.7.19-winx64\bin添加到计 ...

  4. 突破本地离线存储的JS库 localforage

    localforage 简介 项目地址 https://github.com/localForage/localForage API中文地址 https://localforage.docschina ...

  5. C语言多线程pthread库相关函数说明

    线程相关操作说明 一 pthread_t pthread_t在头文件/usr/include/bits/pthreadtypes.h中定义: typedef unsigned long int pth ...

  6. RTSP客户端接收存储数据(live555库中的openRTSP实例)

    一.openRTSP编译运行 a)windows下编译运行 还是以mediaServer作为服务端,openRTSP作为客户端 b)Linux下编译运行 转自http://kuafu80.blog.1 ...

  7. RTSP客户端接收存储数据(live555库中的testRTSPClient实例)

    1.testRTSPClient简介 testRTSPClient是个简单的客户端实例,这个实例对rtsp数据交互作了详细的描述,其中涉及到rtsp会话的两个概念Source和Sink. Source ...

  8. 批量导出存储在msdb库的SSIS包

    http://blog.51cto.com/ultrasql/1924464 use msdb go IF OBJECT_ID('msdb.dbo.usp_ExportSSISPkgs') IS NO ...

  9. caffe 根据txt生成多标签LMDB数据

    1. 前提: 已经准备好train.txt, test.txt文件, 格式如下 此处有坑, 如果是windows下生成txt, 换行符为\r\n, 需要替换成 \n才能在linux运行. 可以使用se ...

随机推荐

  1. rtc关机闹钟3 IAlarmManager

    vim framework/base/core/java/android/app/IAlarmManager.aidl import android.app.AlarmManager;import a ...

  2. php之属性重载和方法重载

    <?php /** * * @authors Your Name (you@example.org) * @date 2016-06-13 20:40:19 * @version $Id$ */ ...

  3. Ajax案例:三级联动查询员工的信息(三张表进行内连接)

    需求分析: 通过数据库连接池,可以查询到数据库中员工的各种信息,通过点击下拉框的方式实现三级联动,即:没有点击city下拉框,后面两个下拉框中没有值,这样,点击city下拉框,department下拉 ...

  4. hdu1081 To the Max

    直接暴力枚举所有子矩形至少需要O(n^4)的复杂度,显然这不是一个合理的解决方法. 上述方案忽略了矩形之间的联系,进行了过多不必要的计算. 实际上如果固定矩形的左右边界,则底边在i行的矩形内数值之和与 ...

  5. LTE切换与TAU问题

    假如有两个LTE基站A B(同频组网) AB TAC不同 且添加了双向邻区关系 现终端开机重选至A然后往B方向移动 是先切换呢?还是先进性TAU更新 这个没有影响,,TAU并非需要在IDLE状态下才能 ...

  6. 性能tips

    Latch 闩 锁的平级 采样时间不能太长,太频繁 一般情况下,性能图应该是一种趋势图,看的是趋势,不看某些单个点 在压测收集数据时,可能多种工具收集到的性能数据有少许差异,原因: 网络延迟,导致收集 ...

  7. ..在lua中运用

    ..连接两个字符串 th> a="hello" th> b="world" th> print(a..b) helloworld th> ...

  8. Java Swing的进化

    摘 要:Swing已是一个比较老的工具集了,在美观的用户界面出来之前需要开发很长时间.它缺少一些你在开发富UI时所需的组件.幸运地是,像 Substance,SwingX及Java Look-and_ ...

  9. Mysql基础语法

    mysql SELECT VERSION(), CURRENT_DATE, now();select user(); create database pets;show databases; use ...

  10. 利用JDBC处理mysql大数据--大文本和二进制文件等

    转载自http://www.cnblogs.com/xdp-gacl/p/3982581.html 一.基本概念 大数据也称之为LOB(Large Objects),LOB又分为:clob和blob, ...