berkerly db 中简单的读写操作(有一些C的 还有一些C++的)
最近在倒腾BDB,才发现自己确实在C++这一块能力很弱,看了一天的api文档,总算是把BDB的一些api之间的关系理清了,希望初学者要理清数据库基本知识中的环境,句柄,游标的基本概念,这样有助于你更好地理解BDB的程序理解理念吧。(此处要注意,BDB的Database相当于一般数据库的数据表,Environment相当于数据库。)
以下是berkerly db的各个文档的介绍:(这是C的,C++的一样)
BDB_Installation.pdf: BDB的安装文档,涵盖了不同操作系统,不同的编译工具,不同编程语言等多方面的详细信息;
BDB_Prog_Reference.pdf: 该文档是使用BDB的开发人员的参考手册,主要从BDB的各种功能和机制的原理进行阐述,供使用BDB作为存储引擎来编写程序的各类程序员(C、Java、C#、Perl)阅读;
BDB-Porting-Guide.pdf: 该文档是给需要将BDB移植到一个新的平台开发人员准备的;
InMemoryDBApplication.pdf: 基于内存的BDB应用的相关知识;
BDB-C_APIReference.pdf: C API参考手册,跟BDB_Prog_Reference.pdf结合使用;
BerkeleyDB-Core-C-GSG.pdf: 为C语言开发人员提供的BDB的入门手册;
BerkeleyDB-Core-C-Txn.pdf: 为C语言开发人员提供的BDB事务方面的手册;
Replication-C-GSG.pdf: 为C语言开发人员提供的BDB复制方面的手册;
具体的介绍我做完这个项目,会详细总结以下,现在先简单说说它的读写,可以节省一些不想看文档的人的时间吧。
首先是C语言的读写,这一块我也是从网上找的,因为C语言的比较简单,自己也没有太多尝试,但是以下代码亲测可用。
这个例子就是建立一个简单的数据库,打开数据库,写一个记录进去,然后读出记录,然后将写入的记录删除,然后关闭environment和数据库。
#include <sys/types.h>
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
//only this head should include for use bdb.
#include <db.h>
#define DATABASE "yangjian.db" int main()
{
DB_ENV *myEnv;
DB *dbp;
DBT key, data;
int ret,t_ret;
u_int32_t env_flags;
//........... Create an environment object and initialize it for error reporting
ret = db_env_create(&myEnv, );
if (ret != )
{
fprintf(stderr, "Error creating env handle: %s\n", db_strerror(ret));
return -;
}
//........If the environment does not exist create it. Initialize the in-memory cache.
env_flags = DB_CREATE | DB_INIT_MPOOL;
//........Open the environment.
ret = myEnv->open(myEnv,"/home/yangbin1/yangjian/my/db/testevn",env_flags,);
if (ret != )
{
fprintf(stderr, "Environment open failed: %s", db_strerror(ret));
return -;
} if ((ret = db_create(&dbp, myEnv, )) != )
{
fprintf(stderr, "db_create: %s\n", db_strerror(ret));
exit ();
} if ((ret = dbp->open(dbp, NULL, DATABASE, NULL, DB_BTREE, DB_CREATE, )) != )
{
dbp->err(dbp, ret, "%s", DATABASE);
exit ();
}
memset(&key, , sizeof(key));
memset(&data, , sizeof(data)); key.data = "sport";
key.size = sizeof("sport");
data.data = "football";
data.size = sizeof("football");
/*
//......put data
if ((ret = dbp->put(dbp, NULL, &key, &data, 0)) == 0)
{
printf("db: %s: key stored.\n", (char *)key.data);
}
else
{
dbp->err(dbp, ret, "DB->put");
}
*/ //........put data NOOVERWRITE
if ((ret = dbp->put(dbp, NULL, &key, &data, DB_NOOVERWRITE)) == )
printf("db: %s: key stored.\n", (char *)key.data);
else dbp->err(dbp, ret, "DB->put"); //.......get data
if ((ret = dbp->get(dbp, NULL, &key, &data, )) == )
printf("db: %s: key retrieved: data was %s.\n", (char *)key.data, (char *)data.data);
else
dbp->err(dbp, ret, "DB->get"); //......del data
if((ret = dbp->del(dbp, NULL, &key, )) == )
printf("db: %s: key was deleted.\n", (char *)key.data);
else
dbp->err(dbp, ret, "DB->del"); //.........close, only when the db successful closed,the data can real write to the disk.
//if ((t_ret = dbp->close(dbp, 0)) != 0 && ret == 0)
//ret = t_ret;
//exit(ret);
if (dbp != NULL)
dbp->close(dbp, );
//.........close evn
//........When you are done with an environment, you must close it.
//........Before you close an environment, make sure you close any opened databases
if (myEnv != NULL)
myEnv->close(myEnv, ); return ;
}
注意ret的使用,在文档中会看到很多关于返回值的叙述,过一段时间我会 认真总结一下。
然后是C++的编写,这里我分为初级版,中级版,以及我暂时还达不到的终极版。
首先是初级版,就是排除了任何异常处理,几乎是最简单的读写操作,这也是我打算在我这个简单的小玩意里使用的。
这一段是我在csdn上找的一个人写的,他总结的比我知道的要多的多:http://blog.csdn.net/mxzy55560593/article/details/7063965
然后是中级版,中级版就是加了简单的异常处理,就是我上一篇博文里的那个简单示例:http://www.cnblogs.com/sexybear/p/3472501.html
最后是终极版,终极版是进行了很复杂的考虑,但也几乎是最保险的了,是oracle的维护人员写的,能写出那样的代码也是我的目标:http://www.bdbchina.com/2009/02/berkeley-db%E7%A4%BA%E4%BE%8B%E7%A8%8B%E5%BA%8F%E8%AF%A6%E8%A7%A3-1/
这些几乎都是我收集来的,还没有我自己写的,是因为我自己能力还没超过这些示例,还是不要献丑了,不过等过一段时间闲下来还是会好好做一些关于BDB的自己的总结的。希望这些能对大家有用吧,谢谢了。
berkerly db 中简单的读写操作(有一些C的 还有一些C++的)的更多相关文章
- 使用Python对Excel表格进行简单的读写操作(xlrd/xlwt)
算是一个小技巧吧,只是进行一些简单的读写操作.让人不爽的是xlrd和xlwt是相对独立的,两个模块的对象不能通用,读写无法连贯操作,只能单独读.单独写,尚不知道如何解决. #①xlrd(读) #cod ...
- kernel中文件的读写操作可以使用vfs_read()和vfs_write
需要在Linux kernel--大多是在需要调试的驱动程序--中读写文件数据.在kernel中操作文件没有标准库可用,需要利用kernel的一些函数,这些函数主要有: filp_open() fil ...
- (六)kernel中文件的读写操作可以使用vfs_read()和vfs_write
需要在Linux kernel--大多是在需要调试的驱动程序--中读写文件数据.在kernel中操作文件没有标准库可用,需要利用kernel的一些函数,这些函数主要有: filp_open() fil ...
- python中文本的读写操作
文本的操作 函数的排序操作: def func(i): return i[2] list=[('曹操',101,'c'),('吕布',100,'d'),('刘备',200,'l'),('大乔',50, ...
- 『无为则无心』Python基础 — 41、Python中文件的读写操作(一)
目录 1.文件操作步骤 2.文件的读写操作 (1)文件的打开 (2)打开文件模式 (3)获取一个文件对象 (4)关于文件路径 1.文件操作步骤 当我们要读取或者写入文件时,我们需要打开文件,在操作完毕 ...
- 在c#中IO流读写操作
1.使用FileStream读写文件 文件头: using System;using System.Collections.Generic;using System.Text;using System ...
- Python中文件的读写操作的几种方法
对文件的操作,步骤为:打开一个文件-->读取/写入内容-->保存文件 文件读写的3中模式 # 1.w 写模式,它是不能读的,如果用w模式打开一个已经存在的文件,会清空以前的文件内容,重新写 ...
- Python中文件的读写操作
文件操作基本流程: 1. 介绍 计算机系统是由计算机硬件,操作系统,和应用程序三部分组成. 内存 存放不持久 硬盘 可以使数据持久化 文件操作 数据持久化的一种 全栈开发 框架类 2. 文件的操作 ...
- ThinkPHP中简单的CURD操作
前言 我们通过一个简答例子来简述CURD的操作.首先看一下数据库的样子,其中id为自增行,其它是varchar 一.查询操作 首先,创建在Controller文件夹下创建一个User控制器,在该控制器 ...
随机推荐
- MHA参数 转
http://blog.csdn.net/wulantian/article/details/12503473 http://blog.csdn.net/wulantian/article/categ ...
- Android精品课程—PullToRefresh 下拉刷新
http://edu.csdn.net/course/detail/1716 TableLayout http://edu.csdn.net/course/detail/2262 Android开发之 ...
- Q_INVOKABLE与invokeMethod用法全解
在Qt/Qt Quick宏浅议一文中,我们将介绍Qt中经常使用的几个宏: Q_OBJECT, SIGNAL与SLOT, Q_SIGNALS 与 Q_SLOTS, Q_EMIT ,Q_INVOKABLE ...
- 代码片段 - Golang 实现简单的 Web 服务器
------------------------------ 下面一段代码,实现了最简单的 Web 服务器: 编译环境: Linux Mint 18 Cinnamon 64-bit Golang 1. ...
- 第一章:Pandas概论
Series:一维数组,与Numpy中的一维array类似.二者与Python基本的数据结构List也很相近,其区别是:List中的元素可以是不同的数据类型,而Array和Series中则只允许存储相 ...
- Redis操作的封装类
using System; using System.Collections.Generic; using System.Linq; using System.Text; using ServiceS ...
- ASP.NET页面与IIS底层交互和工作原理详解(第二回)
引言 在 Part.1 Http请求处理流程 一文中,我们了解了Http请求的处理过程以及其它一些运作原理.我们知道Http管道中有两个可用接口,一个是IHttpHandler,一个是IHttpMod ...
- Oracle 常用的SQL语法和数据对象
一.数据控制语句 (DML) 部分 1.INSERT (往数据表里插入记录的语句) INSERT INTO 表名(字段名1, 字段名2, ……) VALUES ( 值1, 值2, ……); INSE ...
- hdu-5692 Snacks(dfs序+线段树)
题目链接: Snacks Problem Description 百度科技园内有n个零食机,零食机之间通过n−1条路相互连通.每个零食机都有一个值v,表示为小度熊提供零食的价值. 由于零食被频繁的 ...
- [转]如何编译tizen源码(图文教程)?
http://blog.csdn.net/flydream0/article/details/9004746 前一篇文章已经介绍了如何下载tizen源码(http://blog.csdn.net/fl ...