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')
浙公网安备 33010602011771号