leveldb基础操作

leveldb是google实现的一种非常高效的key-value数据库。以下内容仅做记录用。 1、源码安装 下载源码 git clone https://code.google.com/p/leveldb/ 编译源码 cd leveldb && make all 2、python版本的leveldb安装很简单,pip install leveldb 实例脚本 #!/usr/bin/env python #-*-coding: utf-8-*- import leveldb import os, sys #初始化一个数据库students def initialize(): db = leveldb.LevelDB("students"); return db; #插入 def insert(db, sid, name): db.Put(str(sid), name); #删除 def delete(db, sid): db.Delete(str(sid)); #更新 def update(db, sid, name): db.Put(str(sid), name); #搜索 def search(db, sid): name = db.Get(str(sid)); return name; #遍历 def display(db): for key, value in db.RangeIter(): print (key, value); db = initialize(); print "Insert 3 records." insert(db, 1, "Alice"); insert(db, 2, "Bob"); insert(db, 3, "Peter"); display(db); print "Delete the record where sid = 1." delete(db, 1); display(db); print "Update the record where sid = 3." update(db, 3, "Mark"); display(db); print "Get the name of student whose sid = 3." name = search(db, 3); print name; 新建数据库很方便,如果这个目录已经存在就会直接打开,没有的话就会新建。示例中给出了添加,删除,和获取的方法,修改,更新,遍历等基本操作。 **以下摘自网络** 二 、 遍历 如何遍历数据呢,也非常方便,你可以指定开始的key和结束的key,也可以指定顺序,是否带value def test_iter(): db = leveldb.LevelDB('./data') for i in xrange(10): db.Put(str(i), 'string_%s' % i) print list(db.RangeIter(key_from = '2', key_to = '5')) print list(db.RangeIter(key_from = '2', key_to = '5',reverse=True)) def iter_key_values(): db = leveldb.LevelDB('./data') for i in xrange(10): db.Put(str(i), 'string_%s' % i) keys = list(db.RangeIter(include_value = False)) print keys keys_values = list(db.RangeIter()) print keys_values 三、 批量操作 如果我对数据库有一大批操作,每一次都和数据库进行交互,其实挺浪费性能的,因此像mongodb,redis都提供了批量操作的方法,leveldb也是如此。下面是一个清空数据库的例子 def clear_db(): db = leveldb.LevelDB('./data') b = leveldb.WriteBatch() for k in db.RangeIter(include_value = False, reverse = True): b.Delete(k) db.Write(b) b.Delete(k)并没有真正的删除数据,而是在db.Write(b)时执行所有的操作 四、 快照 创建快照非常简单,美中不足的是,再次加载数据库以后,没有方法找到之前创建的快照,难道已关闭这些快照就都不见了,这样的快照还有什么意思呢,也许只有python版本的快照是这样的吧 def test_snapshot(): db = leveldb.LevelDB('./data') db.Put('foo','s1') s1 = db.CreateSnapshot() db.Put('foo','s2') s2 = db.CreateSnapshot() print db.Get('foo') print s1.Get('foo') print s2.Get('foo')

posted on 2018-03-27 17:00  歪歪121  阅读(238)  评论(0)    收藏  举报