- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我正在尝试从 LMDB 存储和获取一些数据。数据似乎已存储,我可以看到数据库中的键,但当我尝试使用刚刚存储的相同 ID 获取值时,它会给出 MDB_NOTFOUND
。
数据库打开
MDB_env* environment;
MDB_dbi main;
MDB_dbi order;
mdb_env_create(&environment);
mdb_env_set_maxdbs(environment, 2);
mdb_env_open(environment, path.toStdString().c_str(), 0, 0664);
int rc;
MDB_txn *txn;
mdb_txn_begin(environment, NULL, 0, &txn);
mdb_dbi_open(txn, "main", MDB_CREATE, &main);
mdb_dbi_open(txn, "order", MDB_CREATE | MDB_INTEGERKEY, &order);
mdb_txn_commit(txn);
插入
void Core::Archive::addElement(const Shared::Message& message) {
QByteArray ba;
QDataStream ds(&ba, QIODevice::WriteOnly);
message.serialize(ds);
uint64_t stamp = message.getTime().toMSecsSinceEpoch();
const std::string& id = message.getId().toStdString();
MDB_val lmdbKey, lmdbData;
lmdbKey.mv_size = id.size();
lmdbKey.mv_data = (uint8_t*)id.c_str();
lmdbData.mv_size = ba.size();
lmdbData.mv_data = (uint8_t*)ba.data();
MDB_txn *txn;
mdb_txn_begin(environment, NULL, 0, &txn);
int rc;
rc = mdb_put(txn, main, &lmdbKey, &lmdbData, 0);
if (rc == 0) {
MDB_val orderKey;
orderKey.mv_size = 8;
orderKey.mv_data = (uint8_t*) &stamp;
rc = mdb_put(txn, order, &orderKey, &lmdbKey, 0);
if (rc) {
mdb_txn_abort(txn);
} else {
rc = mdb_txn_commit(txn);
if (rc) {
qDebug() << "A transaction error: " << mdb_strerror(rc);
}
}
} else {
qDebug() << "An element couldn't been added to the archive, skipping" << mdb_strerror(rc);
mdb_txn_abort(txn);
}
}
获取
Shared::Message Core::Archive::getElement(const QString& id) {
MDB_val lmdbKey, lmdbData;
lmdbKey.mv_size = id.toStdString().size();
lmdbKey.mv_data = (uint8_t*)id.toStdString().c_str();
MDB_txn *txn;
int rc;
mdb_txn_begin(environment, NULL, MDB_RDONLY, &txn);
rc = mdb_get(txn, main, &lmdbKey, &lmdbData);
if (rc) {
qDebug() <<"Get error: " << mdb_strerror(rc);
mdb_txn_abort(txn);
throw NotFound(id.toStdString(), jid.toStdString());
} else {
//it never comes here
}
}
测试代码
Core::Archive ar();
ar.open("Test");
Shared::Message msg1;
msg1.generateRandomId();
msg1.setBody("oldest");
msg1.setTime(QDateTime::currentDateTime().addDays(-7));
Shared::Message msg2;
msg2.generateRandomId();
msg2.setBody("Middle");
msg2.setTime(QDateTime::currentDateTime().addDays(-4));
Shared::Message msg3;
msg3.generateRandomId();
msg3.setBody("newest");
msg3.setTime(QDateTime::currentDateTime());
ar.addElement(msg2);
ar.addElement(msg3);
ar.addElement(msg1);
Shared::Message d0 = ar.getElement(msg1.getId());
我的日志显示存储的 key 。我可以看到所需的 key ,如果我使用光标滚动整个存储,我什至可以将其与请求的 key 进行比较,它甚至显示它们是相等的,但是 mdb_cursor_get
或 mdb_get
不断地给我 MDB_NOTFOUND
。我做错了什么?
最佳答案
我明白了。无论我将什么放入数据库,我都必须将其作为 char* 读取
必须修改获取代码
lmdbKey.mv_data = (uint8_t*)id.toStdString().c_str();
我必须将其更改为
lmdbKey.mv_data = (char*)id.toStdString().c_str();
成功了
关于c++ - 无法从 LMDB 获取值,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/55712327/
在这里发帖是因为我找不到 lmdb 键值存储的任何论坛。 子库有限制吗?并发打开的子数据库的合理数量是多少? 我想要大约 200 个数据库,这看起来很多并且清楚地表明我的模型是错误的。 我想可以重构每
如何获得属于 env 的命名数据库的列表?通过阅读一些 python 绑定(bind)文档 (named database implementation) ,我知道名称存储在主(未命名?)数据库中,但
对现有 lmdb 中的数据进行混洗 ( Trying to solve this problem )。我检索了数据,整理并写回新的 lmdb。但是当我检查 lmdb 文件大小时,它减小了。旧 lmdb
创建 lmdb 环境时,我可以指定 map 大小。有没有办法在任何时候确定用了多少 map 大小? 换句话说,我需要找出剩余多少可用空间才能解决空间不足的问题。 我唯一能想到的就是遍历所有数据库并使用
内存中 B 树的某些 C++ 实现(例如谷歌 btree)和 LMDB(不考虑 LMDB 的所有功能,例如事务、隔离、共享访问等)之间的性能差异(读/写)是什么? .)? 最佳答案 其架构师 Howa
是否可以将多个键映射到同一个值?如果没有,是否有解决此功能的方法? 最佳答案 这是不可能的。我使用的一种解决方法是让第二个键上的值成为指向主键的指针。也就是说,第二个键的值是主键。 特别是,我制作了一
我刚刚开始用 LMDB 替换一些 SQL 表,LMDB 是用 C 实现的基本键值存储 ( lmdb link )。 在移植过程中,我遇到了一些理论问题: 数据库使用游标而不是键入的键,我认为这是因为键
我想使用 the lmdb crate 将一些数据写入我的数据库.我正在写一个枚举: enum MyEnum { A { astr: String, bstr: String }, B
如果您仅从单线程使用 LMDB,并且根本不关心数据库持久性,是否有任何理由打开和关闭事务? 在单个事务中执行所有操作会导致性能问题吗?打开和关闭太多事务是否会影响性能? 我发现我的 LMDB 数据库在
我有一个程序预计会使用 几 GB 的 lmdb 磁盘空间(这是一个区 block 链,我们正在远离 leveldb,因为它的 缺少 ACID,这是我 future 一些计划所需要的)。是否可以在 Ra
我有大约 100 万张图像要放入此数据集中,每次附加 10000 张。 我确信来自此 article 的 ref 的 map_size 是错误的 使用这条线来创建集合 env = lmdb.open(
根据文档 ( https://lmdb.readthedocs.org/en/release/ ),将 dupsort 传递给 open_db() 应该允许将重复键添加到 lmdb 数据库。但情况似乎
我想用同一个键存储多个值。我确保在创建数据库时包含 MDB_DUPSORT 标志。我也知道这限制了值的大小,但在这种特定情况下这不是问题。 当我想使用相同的键读取值时,我的问题就开始了。我进行了搜索,
是否有可以插入 LMDB 数据库的最大值大小?我正在尝试将一个 16GB 的文件插入到初始化为 32GB 的 LMDB 中,但我收到此错误: File "build_lmdb.py", line 90
一般来说,在TF中读取自定义数据我能想到的三种方式: native 实现/自定义数据读取器 https://www.tensorflow.org/versions/r0.10/how_tos/new_
我正在尝试从 LMDB 存储和获取一些数据。数据似乎已存储,我可以看到数据库中的键,但当我尝试使用刚刚存储的相同 ID 获取值时,它会给出 MDB_NOTFOUND 。 数据库打开 MDB_e
我正在处理 lmdb 并且 lmdb 真的很快。但它的一个问题是 lmdb 不是分布式的。每次我需要做一些维护时,lmdb 都必须关闭,并且站点有几个小时不可用。我正在研究如何使 lmdb 成为分布式
我正在尝试将数据写入 lmdb 数据库(引用来自 caffe/tools/convert_imageset.cpp)。控制台中没有错误,但 .mdb 文件的文件大小保持为零,即没有数据写入文件,但创建
我是caffe框架的新手,我想用caffe来实现多标签训练。我使用两个 LMDB 分别保存数据和标签。数据 LMDB 的维度为 Nx1xHxW,而标签 LMDB 的维度为 Nx1x1x3。标签是 fl
当我将最大数据库大小设置为例如 5G 时,在 Windows 上最终的数据库文件大小将变为 5G,即使我只插入一小段数据。但在 Linux 上它工作正常,最终的数据库大小与我插入的数据量有关。 这是我
我是一名优秀的程序员,十分优秀!