Python2.7-dbm、gdbm、dbhash、bsddb、dumbdb
dbm、gdbm、dbhash、bsddb、dumbdb模块,都是操作数据库文件的模块,打开后都会返回对应数据库类型对象,类似字典,有许多操作和字典操作相同,键和值都是以字符串形式保存。dbm 是简单的数据库接口提供 unix 下“(n)dbm”接口,gdbm 是 GNU 系统的数据库接口实现,dbhash 是 BSD 数据库接口实现,bsddb 是 Berkeley 数据库接口实现,dumbdbm 是纯 python 实现不需要外部库的简便数据库接口实现
除了 bsddb,其余打开数据库文件的方式都是 open(filename[, flag[, mode]]):打开数据库文件 filename,flag指定模式(r:只读(默认);w:读写;c:读写如果文件不存在则创建;n:总是创建一个新的数据库读写),mode 指定 unix 模式下的文件类型,仅用于数据库创建,返回对应的对象。
bsddb 由于模块内包括了几种不同类型的数据库因此有不同的打开方法,bsddb.hashopen(filename[, flag[, mode[, pgsize[, ffactor[, nelem[, cachesize[, lorder[, hflags]]]]]]]])、bsddb.btopen(filename[, flag[, mode[, btflags[, cachesize[, maxkeypage[, minkeypage[, pgsize[, lorder]]]]]]]])、bsddb.rnopen(filename[, flag[, mode[, rnflags[, cachesize[, pgsize[, lorder[, rlen[, delim[, source[, pad]]]]]]]]]])。前三个参数都和普通 open 一样,后面参数一般情况都默认,不需要修改,他们的意义和使用方法参考 Berkeley 数据库文档
关闭都是调用 close()
其余不同之处下面一一列举:
1、dbm
1.1 dbm 可以用于 ndbm、BSD DB、GNU GDBM 接口,所以有一个模块属性 dbm.library,返回使用数据库的名字
1.2 dbm 在我的电脑上导入失败,没有这个模块,应该是由于 Windows 系统下没有这类型的数据库
2、gdbm
2.1 gdbm 在 open 时 flag 还可以附加额外的字符(f:快速模式打开文件,数据库的写入不会同步,需要手动保存;s:同步模式,对数据库的修改会马上同步保存;u:打开时不给数据库上锁)
2.2 对象额外方法
firstkey():获得数据库第一个 key 的对应数据。数据排列是根据 gdbm 内部的 hash 值排列的,不能通过 key 的值来排序
nextkey(key):获得 key 后面一个数据,可用于循环遍历
reorganize():重新构建数据库,会把删除的部分所占空间释放。不使用这个方法,被删的空间不会释放,会在下次添加新数据时被重新使用
sync():同步更新,把未写入磁盘的数据写入
2.3 gdbm 在我的电脑上也导入失败,没有这个模块,应该也是由于 Windows 系统下没有这类型的数据库
3、dbhash
3.1 dbhash 在 open 时 flag 可以附加额外字符 l,用于指示数据库需要被锁定,但只能用于支持锁定 BSD db 的平台
3.2 对象额外方法
first():返回第一组键值对数据
last():返回最后一组数据
next():返回下一组数据,和 first 一起使用,遍历数据库
previous():返回之前一组数据,和 last 一起使用,遍历数据库
sync():把未写入磁盘的数据写入
4、bsddb
4.1 bsddb 支持 Berkeley 数据库 4.0 至 4.7 版本
4.2 三种打开方法根据名称分别为:以 hash 格式打开,以 btree 格式打开,以 DB 记录形式打开。具体区别暂时不了解。。
4.3 对象额外方法
keys():列表形式返回数据库文件里包含的键,顺序是不可靠的,是没有特定规律的
has_key(key):判断 key 是否存在数据库中
set_location(key):返回包含键和值的元组,并将 cursor 移至那里。若 key 不存在,以 btree 形式打开的会移至当前数据的下一个,其余会抛出 KeyError
first():返回第一组键值对数据
last():返回最后一组数据
next():返回下一组数据,和 first 一起使用,遍历数据库
previous():返回之前一组数据,和 last 一起使用,遍历数据库
sync():把未写入磁盘的数据写入
5、dumbdbm
5.1 dumbdb 在 open 时 flag 参数会被忽略,永远是 c 模式
5.2 对象额外方法
sync():把未写入磁盘的数据写入。这个方法会在 Shelve 对象调用 sync 时被调用
Python2.7-dbm、gdbm、dbhash、bsddb、dumbdb的更多相关文章
- Python3基础(1)Python介绍、Python2 与Python3、变量、用户输入、if...else和for循环、while循环、break与continue
---------------个人学习笔记--------------- ----------------本文作者吴疆-------------- ------点击此处链接至博客园原文------ P ...
- Python 第五篇(上):算法、自定义模块、系统标准模块(time 、datetime 、random 、OS 、sys 、hashlib 、json和pickle)
一:算法回顾: 冒泡算法,也叫冒泡排序,其特点如下: 1.比较相邻的元素.如果第一个比第二个大,就交换他们两个. 2.对每一对相邻元素作同样的工作,从开始第一对到结尾的最后一对.在这一点,最后的元素应 ...
- MySQL 存储引擎、锁、调优、失误与事务回滚、与python交互、orm
1.存储引擎(处理表的处理器) 1.基本操作 1.查看所有存储引擎 mysql> show engines; 2.查看已有表的存储引擎 mysql> show create table 表 ...
- 编程语言、Python介绍及其解释器安装、运行Python解释器的两种方式、变量、内存管理
一.编程语言介绍 1.1 机器语言:直接用计算机能理解的二进制指令来编写程序,直接控制硬件. 1.2 汇编语言:在机器语言的基础上,用英文标签取代二进制指令来编写程序,本质上也是直接控制硬件. 以上2 ...
- 【05】Python 标准模块:random、os、time、hashlib 第三方模块:excel、数据库 列表生成式
1 模块分类 标准模块,不需要你单独安装,python自带的模块 第三方模块 自己写的python 一个python文件就是一个模块 2 random模块 2.1 随机取元素 import rando ...
- [基本运算符、流程控制之if判断、与用户交互、深浅拷贝]
[基本运算符.流程控制之if判断.与用户交互] 基本运算符 1.算数运算符 python支持的算术运算符与数学上计算的符号使用是一致的 salary = 3.3 res = salary * 12 p ...
- CSS3与页面布局学习总结(二)——Box Model、边距折叠、内联与块标签、CSSReset
一.盒子模型(Box Model) 盒子模型也有人称为框模型,HTML中的多数元素都会在浏览器中生成一个矩形的区域,每个区域包含四个组成部分,从外向内依次是:外边距(Margin).边框(Border ...
- C#、JAVA操作Hadoop(HDFS、Map/Reduce)真实过程概述。组件、源码下载。无法解决:Response status code does not indicate success: 500。
一.Hadoop环境配置概述 三台虚拟机,操作系统为:Ubuntu 16.04. Hadoop版本:2.7.2 NameNode:192.168.72.132 DataNode:192.168.72. ...
- 教你一招:解决win10/win8.1系统在安装、卸载软件时出现2502、2503错误代码的问题
经常遇到win10/win8.1系统在安装.卸载软件时出现2502.2503错误代码的问题. 解决办法: 1.打开任务管理器后,切换到“详细信息”选项卡,找到explore.exe这个进程,然后结束进 ...
随机推荐
- Java - HashSet源码解析
java提高篇(二四)-----HashSet 一.定义 public class HashSet<E> extends AbstractSet<E> implements S ...
- [转载] MySQL的四种事务隔离级别
本文实验的测试环境:Windows 10+cmd+MySQL5.6.36+InnoDB 一.事务的基本要素(ACID) 1.原子性(Atomicity):事务开始后所有操作,要么全部做完,要么全部不做 ...
- apache2.2 +php7.3安装 编译安装
1.下载 http://archive.apache.org/dist/httpd/httpd-2.2.0.tar.gz tar -xvf httpd-2.2.0.tar.gz 2.安装 ./conf ...
- @Schedul 中cron的命名规则
@Schedul注解的定时任务详解 1.springboot集成schedule由于Spring Schedule包含在spring-boot-starter基础模块中了,所有不需要增加额外的依赖. ...
- 纯小白入手 vue3.0 CLI - 2.4 - 新组件 Forms.vue 中学习表单
vue3.0 CLI 真小白一步一步入手全教程系列:https://www.cnblogs.com/ndos/category/1295752.html 我的 github 地址 - vue3.0St ...
- 《Spring实战》-- 'cvc-complex-type.2.4.c: The matching wildcard is strict, but no declaration can be found for element' 错误的解决办法
在Eclipse中新建了一个maven项目学习Spring,在 service.xml 中配置 Spring,想要学习'面向切面的Spring',service.xml 内容如下: <beans ...
- java基础知识文章汇总
将之前的所有关于Java基础知识的随笔,整理成质量较高的十几篇随笔,几乎是好几篇比较零散的随笔合成现在的一篇,自认为还不错. java基础(一) 深入解析基本类型 java基础(二) 自增自减与贪心规 ...
- Spring Boot (#1 quick start)
Spring Boot (#1 quick start) 官方文档 Spring Boot是为了简化Spring应用的创建.运行.调试.部署等而出现的,使用它可以做到专注于Spring应用的开发,而无 ...
- centos6.5安装mysql
1.yum -install mysql mysql-server -y 2.修改mysql的root的密码 登录:mysql -uroot 修改密码: use ...
- java web dev知识积累
tomcat体系结构 可以从tomcat的server.xml文件中元素的层次结构来理解tomcat的体系结构: Server(可以视为tomcat本身)->经由connector可以有多个(c ...