快速了解python leveldb
作者:kwsy2008 时间:2023-06-03 11:12:19
本文主要是对leveldb进行一个简单的介绍及使用Python语言对其进行操作的代码示例,具体如下。
leveldb 是google实现的一种非常高效的key-value数据库。key-value数据库中,redis是比较知名且好用的,但它是一个内存数据库,而leveldb只需要少量的内存,但速度依然很快,美中不足的是,没有网络服务封装,这样一来就只能单机使用,如果你实力足够强,也可以自己封装一个。
python版本的leveldb安装很简单,pip install leveldb
接下来重点介绍使用方法。
一 、 读写
def single_operate():
db = leveldb.LevelDB('./data')
db.Put('foo','东升')
print db.Get('foo')
db.Delete('foo')
print db.Get('foo')
新建数据库很方便,如果这个目录已经存在就会直接打开,没有的话就会新建。示例中给出了添加,删除,和获取的方法,注意,是没有修改操作的。
二 、 遍历
如何遍历数据呢,也非常方便,你可以指定开始的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')
来源:http://blog.csdn.net/kwsy2008/article/details/52326204
标签:python,leveldb,数据库
0
投稿
猜你喜欢
了解WEB页面工具语言XML(四)应用分类
2008-09-05 17:18:00
使用python验证代理ip是否可用的实现方法
2021-03-22 05:30:16
Python列表解析配合if else的方法
2021-10-08 06:50:11
精致的web设计
2009-12-04 19:07:00
17个vue常用的数组方法总结与实例演示
2024-06-07 16:06:07
php递归删除目录与文件的方法
2023-09-12 02:02:02
Mysql锁内部实现机制之C源码解析
2024-01-12 21:13:25
Web开发的改良
2009-06-25 14:34:00
利用python写个下载teahour音频的小脚本
2021-05-17 06:05:54
python利用pd.cut()和pd.qcut()对数据进行分箱操作
2022-03-26 07:57:45
Python实现贪吃蛇小游戏(双人模式)
2021-06-07 11:15:02
OpenCV-Python实现图像平滑处理操作
2021-06-19 10:28:21
Python接单的过程记录分享
2022-05-24 13:33:23
Python利用Pytorch实现绘制ROC与PR曲线图
2022-09-20 03:24:20
Python实现对二维码数据进行压缩
2022-10-22 12:51:59
js阻止移动端页面滚动的两种方法
2023-08-04 17:36:12
python使用wxpython开发简单记事本的方法
2022-05-15 18:06:12
python中Task封装协程的知识点总结
2022-10-25 13:25:02
IE7异常CSS 导致内存破坏漏洞
2009-11-30 12:52:00
解决golang读取http的body时遇到的坑
2024-02-13 19:47:32