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中利用sorted()函数排序的简单教程
Apr 27 Python
使用Python神器对付12306变态验证码
Jan 05 Python
Python切片知识解析
Mar 06 Python
Python制作刷网页流量工具
Apr 23 Python
利用Tkinter(python3.6)实现一个简单计算器
Dec 21 Python
Python tkinter实现的图片移动碰撞动画效果【附源码下载】
Jan 04 Python
Python 12306抢火车票脚本
Feb 07 Python
python3字符串操作总结
Jul 24 Python
python的time模块和datetime模块实例解析
Nov 29 Python
python扫描线填充算法详解
Feb 19 Python
Python selenium爬取微博数据代码实例
May 22 Python
python 多态 协议 鸭子类型详解
Nov 27 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
按上下级层次关系输出内容的PHP代码
2010/07/17 PHP
phpMyAdmin 链接表的附加功能尚未激活问题的解决方法(已测)
2012/03/27 PHP
PHP通过调用新浪API生成t.cn格式短网址链接的方法详解
2019/02/20 PHP
Prototype使用指南之array.js
2007/01/10 Javascript
超轻量级的基于jquery的三级展开列表
2011/04/26 Javascript
js控制的遮罩层实例介绍
2013/05/29 Javascript
javascript 获取图片尺寸及放大图片
2013/09/04 Javascript
extjs 时间范围选择自动判断的实现代码
2014/06/24 Javascript
js使用递归解析xml
2014/12/12 Javascript
JavaScript中创建字典对象(dictionary)实例
2015/03/31 Javascript
js实时获取并显示当前时间的方法
2015/07/31 Javascript
js鼠标点击图片切换效果代码分享
2015/08/26 Javascript
浅谈JavaScript 中有关时间对象的方法
2016/08/15 Javascript
老生常谈JQuery data方法的使用
2016/09/09 Javascript
Bootstrap Table的使用总结
2016/10/08 Javascript
vue中的自定义分页插件组件的示例
2018/08/18 Javascript
vue中的inject学习教程
2019/04/24 Javascript
微信小程序实现发送模板消息功能示例【通过openid推送消息给用户】
2019/05/05 Javascript
JavaScript this在函数中的指向及实例详解
2019/10/14 Javascript
JavaScript实现简单的图片切换功能(实例代码)
2020/04/10 Javascript
[01:02:54]完美世界DOTA2联赛PWL S2 FTD vs GXR 第一场 11.22
2020/11/26 DOTA
使用python读取txt文件的内容,并删除重复的行数方法
2018/04/18 Python
python事件驱动event实现详解
2018/11/21 Python
Python面向对象之类和对象属性的增删改查操作示例
2018/12/14 Python
python进行TCP端口扫描的实现
2018/12/21 Python
python开发准备工作之配置虚拟环境(非常重要)
2019/02/11 Python
浅谈Python3中strip()、lstrip()、rstrip()用法详解
2019/04/29 Python
python rsa实现数据加密和解密、签名加密和验签功能
2019/09/18 Python
Python爬虫库requests获取响应内容、响应状态码、响应头
2020/01/25 Python
葡萄牙航空官方网站:TAP Air Portugal
2019/10/31 全球购物
泰国时尚电商:POMELO Fashion
2020/03/11 全球购物
size?法国官网:英国伦敦的球鞋精品店
2020/03/15 全球购物
幼儿园教师安全责任书
2015/05/08 职场文书
培根随笔读书笔记
2015/07/01 职场文书
MySQL 中如何归档数据的实现方法
2022/03/16 SQL Server
python数字图像处理实现图像的形变与缩放
2022/06/28 Python