文章目录
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