绑定完请刷新页面
取消
刷新

分享好友

×
取消 复制
mapdb-
2022-04-13 17:20:54

1.概述

  一个内存数据库,以map形式保存数据,可以持久化到磁盘。

2.demo

复制代码
import org.mapdb.*;

DB db = DBMaker.newFileDB(new File("testdb"))
               .closeOnJvmShutdown()
               .encryptionEnable("password")
               .make();

ConcurrentNavigableMapmap = db.getTreeMap("collectionName");

map.put(1, "1");
map.put(2, "2);

db.commit();

map.put(3, "three");
// map.keySet() is now [1,2,3]
db.rollback(); //revert recent changes

db.close();
复制代码

2.结构

  外部接口为map形式,内部将数据序列化,然后以卷的形式保存在内存中,数据的基本类型是经过封装的都是通过内存中位置来读取数据。

  每个Engine包含多个卷,事务是通过复制卷的副本等逻辑完成后复制回去来完成的。

  卷本身是一个内存块,有内存和文件的重载。

  db除了提供map以外还负责管理事务。

  db事务的处理其实是engine的事务

分享好友

分享这个小栈给你的朋友们,一起进步吧。

MapDB
创建时间:2022-04-13 17:18:51
MapDB
展开
订阅须知

• 所有用户可根据关注领域订阅专区或所有专区

• 付费订阅:虚拟交易,一经交易不退款;若特殊情况,可3日内客服咨询

• 专区发布评论属默认订阅所评论专区(除付费小栈外)

技术专家

查看更多
  • LCR_
    专家
戳我,来吐槽~