使用怎么Java怎么操作数据库leveldb-创新互联
使用怎么Java怎么操作数据库leveldb?很多新手对此不是很清楚,为了帮助大家解决这个难题,下面小编将为大家详细讲解,有这方面需求的人可以来学习下,希望你能有所收获。
成都创新互联2013年至今,是专业互联网技术服务公司,拥有项目成都网站制作、成都网站建设网站策划,项目实施与项目整合能力。我们以让每一个梦想脱颖而出为使命,1280元定远做网站,已为上家服务,为定远各地企业和个人服务,联系电话:18982081108引入SDK
org.iq80.leveldb leveldb-api 0.10 org.iq80.leveldb leveldb 0.10
初始化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 LinkedHashMapiteratorDb() { DBIterator iterator = db.iterator(); LinkedHashMap linkedHashMap = new LinkedHashMap<>(); while (iterator.hasNext()) { Map.Entry next = iterator.next(); String key = Iq80DBFactory.asString(next.getKey()); String value = Iq80DBFactory.asString(next.getValue()); linkedHashMap.put(key, value); } return linkedHashMap; }
测试插入一百万条数据
基于SpringBoot搭建的控制器
随机生成 指定数量的UUID 并且插入到LevelDB
从请求 到响应 5.5秒左右 如果再抛掉生成UUID的时间 可能更快 哈哈
@ResponseBody @GetMapping("/generate") public ResponeEntity generate(Long count) { DB db = levelDb.getDb(); //创建批量处理 WriteBatch batch = db.createWriteBatch(); for (int i = 0; i < count; i++) { String uuid = UUID.randomUUID().toString(); batch.put(Iq80DBFactory.bytes(uuid), Iq80DBFactory.bytes(uuid)); } //执行写入 db.write(batch); return buildRespone(null); }
测试从一百万数据中取出一条
PostMan 请求到响应时间 19毫秒
@ResponseBody @GetMapping("/getLevel") public ResponeEntity getLevel(String key) { byte[] bytes = db.get(Iq80DBFactory.bytes(key)); String value = Iq80DBFactory.asString(bytes); return buildRespone(value); }
看完上述内容是否对您有帮助呢?如果还想对相关知识有进一步的了解或阅读更多相关文章,请关注创新互联行业资讯频道,感谢您对创新互联网站建设公司,的支持。
分享文章:使用怎么Java怎么操作数据库leveldb-创新互联
新闻来源:http://cdiso.cn/article/hsspe.html