对H2的[MVStore]: http://www.cnblogs.com/simoncook/p/5188105.html 这篇文章的补充。
概述
我们通常用的map,比如HashMap LinkedHashMap ConcurrentHashMap这些基本能力是用来存储kv,并能按key获取,支持泛型,提供对整个map进行迭代(含entryset迭代),有些还提供顺序放入功能,有些还提供并发存和取的能力。
那么h2的MVMap多提供了哪些特殊的能力?
MVMap提供的能力
- 与
MVStore
配合支持持久化,且此特性具有开关 - 对put的数据有版本的概念,支持打开一个过去版本(旧版本)的
MVMap
的实例,并且支持旧版本的个数可以设置。
MVStore提供的能力
同样从 TestMVStore
测试用例着手分析:
- 支持开启一个命名的
MVMap
,支持命名map的rename。 - 支持 commit与rollback操作。
回滚操作不仅支持MVMap
的put动作 还支持从MVStore
中remove map的操作等。但是remove map的操作进行rollback时 仅仅能将map rollback回来,map中的数据不能回滚回来了。 支持命名map的rename的动作回滚。 - 通过
MVMap
的isVolatile
标识,支持对管理的MVMap可选持久化。 - 支持压缩与高压缩比压缩。
- 通过
MVMap
的能力打开指定版本的数据。 - 支持文件存储,支持堆外存储。
- 支持commit动作的延时时间设置。
- 支持存储加密。