前言:
而今大家对“pythonleveldb”大体比较关怀,看官们都需要知道一些“pythonleveldb”的相关内容。那么小编也在网上收集了一些关于“pythonleveldb””的相关知识,希望各位老铁们能喜欢,兄弟们快快来学习一下吧!前言
LevelDB 是一种Key-Value存储数据库,性能非常强悍,可以支撑十亿级(来自百度上说明)
优点key与value采用字符串形式,且长度没有限制数据能持久化存储,同时也能将数据缓存到内存,实现快速读取基于key按序存放数据,并且key的排序比较函数可以根据用户需求进行定制支持简易的操作接口API,如Put、Get、Delete,并支持批量写入可以针对数据创建数据内存快照支持前向、后向的迭代器采用Google的Snappy压缩算法对数据进行压缩,以减少存储空间基本不依赖其他第三方模块,可非常容易地移植到Windows、Linux、UNIX、Android、iOS。缺点不是传统的关系数据库,不支持SQL查询与索引只支持单进程,不支持多进程不支持多种数据类型不支持客户端-服务器的访问模式。用户在应用时,需要自己进行网络服务的封装引入 SDK
<dependency> <groupId>org.iq80.leveldb</groupId> <artifactId>leveldb-api</artifactId> <version>0.10</version></dependency><dependency> <groupId>org.iq80.leveldb</groupId> <artifactId>leveldb</artifactId> <version>0.10</version></dependency>初始化 DB
DBFactory factory = new Iq80DBFactory();Options options = new Options();options.createIfMissing(true);//folder 是db存储目录DB db = factory.open(new File(folder), options);存储 Key Value 值
//levelDB 的api存储都是字节数组 所以这里需要转成字节数组db.put(Iq80DBFactory.bytes(key), Iq80DBFactory.bytes(value));获取 Value
byte[] bytes = db.get(Iq80DBFactory.bytes(key));String value = Iq80DBFactory.asString(bytes);删除 | 更改
//删除db.delete(Iq80DBFactory.bytes(key));//更改 重新put新的key - value即可db.put(Iq80DBFactory.bytes(key), Iq80DBFactory.bytes(value));遍历所有数据
public LinkedHashMap<String, String> iteratorDb() { DBIterator iterator = db.iterator(); LinkedHashMap<String, String> linkedHashMap = new LinkedHashMap<>(); while (iterator.hasNext()) { Map.Entry<byte[], byte[]> next = iterator.next(); String key = Iq80DBFactory.asString(next.getKey()); String value = Iq80DBFactory.asString(next.getValue()); linkedHashMap.put(key, value); } return linkedHashMap;}
版权声明:
本站文章均来自互联网搜集,如有侵犯您的权益,请联系我们删除,谢谢。
标签: #pythonleveldb