Python bsddb模块操作Berkeley DB数据库介绍


Posted in Python onApril 08, 2015

bsddb模块是用来操作bdb的模块,bdb是著名的Berkeley DB,它的性能非常好,mysql的存储后端引擎都支持bdb的方式。这里简单介绍一些关于bsddb的使用方法。

bdb不同于一般的关系数据库,它存储的数据只能是以key和value组成的一对数据,使用就像python的字典一样,它不能直接表示多个字段,当要存储多个字段的数据时,只能把数据作为一个整体存放到value中。

使用bsddb面临的第一问题是使用什么数据访问方法,bdb支持四种:btree, hash, queue, recno。这里先说说它们有什么区别,btree是用的树结构来才存储的数据,查询速度很快,可以存储任意复杂的key和value。hash是用的hash算法,速度其实和btree比差不多的,但是当数据量特别巨大时,应该使用hash。queue是队列操作,它有一个限制,它只能存储定长的数据,也就是说value的长度是固定的!但是queue可以保持数据的先进先出,并且对数据的插入做了特殊的优化,并且提供行级锁。queue的key必须是数字。recno和queue类似,但是它可以支持变长的value,它的key同样也是数字。

    这里先对这四种数据访问方法分别做打开数据库,简单插入一条数据的演示。
对于python的bsddb模块来说,打开数据库的操作有两种方式,一是使用原始的接口,就是先打开一个环境,然后从这个环境中打开一个数据库,就像下面:

import bsddb
dbenv = bsddb.db.DBEnv()

dbenv.open(home, bsddb.db.DB_CREATE | bsddb.db.DB_INIT_MPOOL)

d = bsddb.db.DB(dbenv)

d.open(filename, bsddb.db.DB_BTREE, bsddb.db.DB_CREATE, 0666)

还有一种方式是python特有的,这个是bsddb模块本身对上面的过程做了包装,比如打开btree的:

import bsddb
db = bsddb.btopen('test.db', 'c')

看起来比上面的简单多了吧。但这种方式提供的接口很有限,也只有很简单的功能,没有第一种的灵活,但是它在python2.5的版本里是线程安全的。这里都介绍一下。
看看一个例子:

#-*- encoding: gb2312 -*-

import os, sys, string

import bsddb, time
home = "db_home"

filename = "test.db"

try:

    # 创建home目录

    os.mkdir(home)

except:

    pass
# 创建数据库环境

dbenv = bsddb.db.DBEnv()

# 打开数据库环境

dbenv.open(home, bsddb.db.DB_CREATE | bsddb.db.DB_INIT_MPOOL)

# 创建数据库对象

d = bsddb.db.DB(dbenv)

# 打开数据库, 这里的第二个参数就是指定使用什么数据访问方法

# btree是 bsddb.db.DB_BTREE, hash是bsddb.db.DB_HASH

# queu 是 bsddb.db.DB_QUEUE,  recno 是bsddb.db.DB_RECNO

d.open(filename, bsddb.db.DB_BTREE, bsddb.db.DB_CREATE, 0666)

# 插入一条数据,注意queue和recno的key不能是字符串的,应该是数字

d.put('test1', 'zhaowei')    

print d.items()

# 关闭,这时会把数据写回文件

d.close()

dbenv.close()

下面来个使用queue的,注意看有什么区别:
#-*- encoding: gb2312 -*-

import os, sys, string

import bsddb, time
home = "db_home"

filename = "testqueue.db"

try:

    os.mkdir(home)

except:

    pass
dbenv = bsddb.db.DBEnv()

dbenv.open(home, bsddb.db.DB_CREATE | bsddb.db.DB_INIT_MPOOL)

d = bsddb.db.DB(dbenv)

# queue必须要设置一个value的长度,它的value是定长的

d.set_re_len(40)

d.open(filename, bsddb.db.DB_QUEUE, bsddb.db.DB_CREATE, 0666)

# 它的key必须是数字

d.put(1, 'zhaowei')

print d.items()
d.close()

dbenv.close()

那简单的第二种方式使用如下, 要简洁很多了:
import bsddb
d = bsddb.hashopen("aaa.db", "c")

d['test1'] = "zhaowei"

print d.items()

d.close()
Python 相关文章推荐
使用Python编写简单网络爬虫抓取视频下载资源
Nov 04 Python
python实现基于两张图片生成圆角图标效果的方法
Mar 26 Python
利用Python抓取行政区划码的方法
Nov 28 Python
Python实现打印螺旋矩阵功能的方法
Nov 21 Python
Python爬虫爬取一个网页上的图片地址实例代码
Jan 16 Python
Python实现合并同一个文件夹下所有PDF文件的方法示例
Apr 28 Python
Python面向对象类的继承实例详解
Jun 27 Python
Django集成CAS单点登录的方法示例
Jun 10 Python
selenium 多窗口切换的实现(windows)
Jan 18 Python
Python读取VOC中的xml目标框实例
Mar 10 Python
idea2020手动安装python插件的实现方法
Jul 17 Python
Python Pillow(PIL)库的用法详解
Sep 19 Python
Python使用scrapy采集数据过程中放回下载过大页面的方法
Apr 08 #Python
在Python中使用M2Crypto模块实现AES加密的教程
Apr 08 #Python
Python使用scrapy采集时伪装成HTTP/1.1的方法
Apr 08 #Python
Python打印scrapy蜘蛛抓取树结构的方法
Apr 08 #Python
使用IPython来操作Docker容器的入门指引
Apr 08 #Python
仅用50行Python代码实现一个简单的代理服务器
Apr 08 #Python
用Python实现一个简单的能够发送带附件的邮件程序的教程
Apr 08 #Python
You might like
PHP5与MySQL数据库操作常用代码 收集
2010/03/21 PHP
thinkphp实现like模糊查询实例
2014/10/29 PHP
php实现字符串翻转的方法
2015/03/27 PHP
php经典算法集锦
2015/11/14 PHP
php curl模拟post请求和提交多维数组的示例代码
2015/11/19 PHP
xmlHTTP实例
2006/10/24 Javascript
清除网页历史记录,屏蔽后退按钮!
2008/12/22 Javascript
javascript 节点排序 2
2011/01/31 Javascript
JavaScript可否多线程? 深入理解JavaScript定时机制
2012/05/23 Javascript
扩展IE中一些不兼容的方法如contains、startWith等等
2014/01/09 Javascript
AngularJS实现表单手动验证和表单自动验证
2015/12/09 Javascript
JS显示日历和天气的方法
2016/03/01 Javascript
JS实用技巧小结(屏蔽错误、div滚动条设置、背景图片位置等)
2016/06/16 Javascript
Chrome不支持showModalDialog模态对话框和无法返回returnValue问题的解决方法
2016/10/30 Javascript
利用JS判断字符串是否含有数字与特殊字符的方法小结
2016/11/25 Javascript
在Debian(Raspberry Pi)树莓派上安装NodeJS的教程详解
2017/09/19 NodeJs
vue底部加载更多的实例代码
2018/06/29 Javascript
Vue的路由及路由钩子函数的实现
2019/07/02 Javascript
js实现金山打字通小游戏
2020/07/24 Javascript
JavaScript实现与web通信的方法详解
2020/08/07 Javascript
js实现拖拽元素选择和删除
2020/08/25 Javascript
详解Python2.x中对Unicode编码的使用
2015/04/03 Python
django自带的server 让外网主机访问方法
2018/05/14 Python
Python3+Pycharm+PyQt5环境搭建步骤图文详解
2019/05/29 Python
python带参数打包exe及调用方式
2019/12/21 Python
联想澳大利亚官网:Lenovo Australia
2018/01/18 全球购物
澳大利亚婴儿礼品公司:The Baby Gift Company
2018/11/04 全球购物
Fanatics英国官网:美国体育电商
2018/11/06 全球购物
计算机专业优秀大学生自我总结
2014/01/21 职场文书
部队万能检讨书
2014/02/20 职场文书
产品销售计划书
2014/05/04 职场文书
公务员群众路线专题民主生活会发言材料
2014/09/17 职场文书
群众路线教育实践活动对照检查材料
2014/09/22 职场文书
2014年采购部工作总结
2014/11/20 职场文书
学校党支部承诺书
2015/04/30 职场文书
保安辞职申请书应该怎么写?
2019/07/15 职场文书