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 相关文章推荐
写了个监控nginx进程的Python脚本
May 10 Python
python解决字典中的值是列表问题的方法
Mar 04 Python
python 3利用Dlib 19.7实现摄像头人脸检测特征点标定
Feb 26 Python
django初始化数据库的实例
May 27 Python
详解flask表单提交的两种方式
Jul 21 Python
解决python xlrd无法读取excel文件的问题
Dec 25 Python
Python数据结构之栈、队列及二叉树定义与用法浅析
Dec 27 Python
python实现维吉尼亚算法
Mar 20 Python
Python3之手动创建迭代器的实例代码
May 22 Python
基于python图像处理API的使用示例
Apr 03 Python
Ubuntu18.04安装 PyCharm并使用 Anaconda 管理的Python环境
Apr 08 Python
Python pygame实现中国象棋单机版源码
Jun 20 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
为IP查询添加GOOGLE地图功能的代码
2010/08/08 PHP
php ci框架中加载css和js文件失败的解决方法
2014/03/03 PHP
php封装的图片(缩略图)处理类完整实例
2016/10/19 PHP
JavaScript 不只是脚本
2007/05/30 Javascript
原生js代码实现图片放大境效果
2016/10/30 Javascript
巧用数组制作图片切换js代码
2016/11/29 Javascript
jQuery电话号码验证实例
2017/01/05 Javascript
JS判断键盘是否按的回车键并触发指定按钮点击操作的方法
2017/02/13 Javascript
json的结构与遍历方法实例分析
2017/04/25 Javascript
HTML5开发Kinect体感游戏的实例应用
2017/09/18 Javascript
浅谈webpack编译vue项目生成的代码探索
2017/12/11 Javascript
浅谈Vue数据绑定的原理
2018/01/08 Javascript
详解JavaScript的BUG和错误
2018/05/07 Javascript
JS实现面向对象继承的5种方式分析
2018/07/21 Javascript
node中的密码安全(加密)
2018/09/17 Javascript
vue给对象动态添加属性和值的实例
2019/09/09 Javascript
Python实现根据IP地址和子网掩码算出网段的方法
2015/07/30 Python
Python排序搜索基本算法之希尔排序实例分析
2017/12/09 Python
python实现爬取百度图片的方法示例
2019/07/06 Python
python Django的web开发实例(入门)
2019/07/31 Python
Python openpyxl读取单元格字体颜色过程解析
2019/09/03 Python
三步解决python PermissionError: [WinError 5]拒绝访问的情况
2020/04/22 Python
CSS3控制HTML元素动画效果
2014/02/08 HTML / CSS
印度在线购物网站:Paytmmall
2019/07/24 全球购物
TALLY WEiJL法国网上商店:服装、时装及配饰
2019/08/31 全球购物
婚鞋、新娘鞋、礼服鞋、童鞋:Nina Shoes
2019/09/04 全球购物
奥地利婴儿用品和玩具购物网站:baby-markt.at
2020/01/26 全球购物
俄罗斯儿童和青少年服装、鞋子及配件的在线商店:Orby
2020/02/20 全球购物
请描述一下”is a”关系和”has a”关系
2015/02/03 面试题
结构和类有什么异同
2012/07/16 面试题
《理想》教学反思
2014/02/17 职场文书
党员群众路线自我剖析材料
2014/10/06 职场文书
先进班集体申报材料
2014/12/26 职场文书
2015年政务公开工作总结
2015/05/19 职场文书
2015年评职称个人工作总结
2015/10/15 职场文书
pytorch 中autograd.grad()函数的用法说明
2021/05/12 Python