首页 > 解决方案 > LMDB 是否支持多个键到相同的值映射?

问题描述

是否可以将多个键映射到相同的值?如果没有,是否有解决此功能的方法?

标签: leveldblmdb

解决方案


这是不可能的。我使用的一种解决方法是让第二个键上的值成为指向主键的指针。即第二个键的值主键。

特别是,我制作了一个辅助键表(或 lmdb 中的“命名数据库”),其中所有都是主表中的主键。如果您进一步研究其他数据库,这正是它们实现索引的方式。


例如

Data table:
    key: 72E13E60-85A6-4191-A187-F6FA5D3F0975
    value: {
       "surrogate-key": "72E13E60-85A6-4191-A187-F6FA5D3F0975",
       "name": "Foo Widget",
       "location": "Atlantis Mall",
       "last-value": 892
    }
Name table:
    key: "Foo Widget",
    value: "72E13E60-85A6-4191-A187-F6FA5D3F0975"
Location table:
    key: "Atlantis Mall",
    value: "72E13E60-85A6-4191-A187-F6FA5D3F0975"

推荐阅读