文章目录
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
fileDB
将数据写入到磁盘中,并从磁盘中读取数据heapDB
,创建一个新的内存数据库,将数不经过序列化存储在堆内存上。这种模式读取速度非常的快,但是数据会影响到GC,这种方式和JDK自带的集合框架十分相似。 <