MapDb学习笔记

MapDb学习笔记

一、介绍

MapDb是一个开源的,内嵌的Java数据引擎和集合框架。提供了Map,Set,List,Queue,BitMap,支持范围查询,数据过期,压缩,堆外存储的特性。MapDb很有可能是性能最好的Java数据库,它的性能可以和Java.util包下面的集合相媲美。MapDB还提供了一些优秀的特性,比如说ACID事务,数据快照和增量备份等等。

二、快速开始

MapDb是非常灵活的,因为它有许多的可配置选项。但是在绝大数数的例子中,只需要几行代码就可以配置。

依赖如下:

<dependency>
    <groupId>org.mapdb</groupId>
    <artifactId>mapdb</artifactId>
    <version>VERSION</version>
 </dependency>

Hello World

基于内存

  DB db = DBMaker.memoryDB().make();
  HTreeMap<String, String> map = db.hashMap("map")
                .keySerializer(Serializer.STRING)
                .valueSerializer(Serializer.STRING)
                .createOrOpen();
   //类似于JDK中Map的操作
  map.put("name","bob");

基于文件

    @Test
    public void test02(){
   
        DB db = DBMaker.fileDB("cache")
               .make();
        HTreeMap<String, byte[]> cache = db.hashMap("cache")
                .keySerializer(Serializer.STRING)
                .valueSerializer(Serializer.BYTE_ARRAY)
                .createOrOpen();
        Person person = new Person();
        person.setId(1);
        person.setName("Josiah");
        person.setAddress("四川省成都市");
        cache.put("name", object2Bytes(person));
        byte[] bytes = cache.get("name");
        Object o = bytes2Object(bytes);
        if(o instanceof Person){
   
            Person p = (Person)o;
            System.out.println(p);
        }
        db.close();
    }

快速提示

  • 在64位操作系统上,把内存数据映射到文件的时性能会更好。
  • MapDB针对批量导入提供了 Pump。这个比Map.put()操作性能更好
  • 事务虽然存在一些性能开销,但是如果没有事务当程序没有正常关闭时,存储就会损坏。
  • 存储在MapDb上的(键和值)都应该是不变的。
  • MapDB有时候需要压缩。

DB 和 DBMaker

  • DbMaker的DB mode

    1. fileDB将数据写入到磁盘中,并从磁盘中读取数据
    2. heapDB,创建一个新的内存数据库,将数不经过序列化存储在堆内存上。这种模式读取速度非常的快,但是数据会影响到GC,这种方式和JDK自带的集合框架十分相似
  • 0
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值