SQLite3 API 使用大全 E-mail:18918737 (at) qq dot com,智有不明
return 0;
}
为什么要 extern “C” ?如果问这个问题,我不想说太多,这是 C++的基础。要在 C++ 里
使用一段 C 的代码,必须要用 extern “C” 括起来。C++跟 C 虽然语法上有重叠,但是它
们是两个不同的东西,内存里的布局是完全不同的,在 C++编译器里不用 extern “C”括起 C
代码,会导致编译器不知道该如何为 C 代码描述内存布局。
可能在 sqlite3.c 里人家已经把整段代码都 extern “C” 括起来了,但是你遇到一个
.c 文件就自觉的再括一次,也没什么不好。
基本工程就这样建立起来了。编译,可以通过。但是有一堆的 warning。可以不管它。
三、 SQLITE 操作入门
sqlite 提供的是一些 C 函数接口,你可以用这些函数操作数据库。通过使用这些接口,传递
一些标准 sql 语句(以 char * 类型)给 sqlite 函数,sqlite 就会为你操作数据库。
sqlite 跟 MS 的 access 一样是文件型数据库,就是说,一个数据库就是一个文件,此数据
库里可以建立很多的表,可以建立索引、触发器等等,但是,它实际上得到的就是一个文件。
备份这个文件就备份了整个数据库。
sqlite 不需要任何数据库引擎,这意味着如果你需要 sqlite 来保存一些用户数据,甚至
都不需要安装数据库(如果你做个小软件还要求人家必须装了 sqlserver 才能运行,那也太
黑心了)。
下面开始介绍数据库基本操作。
(1) 基本流程
i.1 关键数据结构
sqlite 里最常用到的是 sqlite3 * 类型。从数据库打开开始,sqlite 就要为这个类型
准备好内存,直到数据库关闭,整个过程都需要用到这个类型。当数据库打开时开始,这个类
型的变量就代表了你要操作的数据库。下面再详细介绍。
i.2 打开数据库
int sqlite3_open( 文件名, sqlite3 ** );
用这个函数开始数据库操作。
需要传入两个参数,一是数据库文件名,比如:c://DongChunGuang_Database.db。
文件名不需要一定存在,如果此文件不存在,sqlite 会自动建立它。如果它存在,就尝试把
它当数据库文件来打开。
sqlite3 ** 参数即前面提到的关键数据结构。这个结构底层细节如何,你不要关它。
函数返回值表示操作是否正确,如果是 SQLITE_OK 则表示操作正常。相关的返回值 sqlite
定义了一些宏。具体这些宏的含义可以参考 sqlite3.h 文件。里面有详细定义(顺便说一
下,sqlite3 的代码注释率自称是非常高的,实际上也的确很高。只要你会看英文,sqlite
可以让你学到不少东西)。
下面介绍关闭数据库后,再给一段参考代码。
i.3 关闭数据库
int sqlite3_close(sqlite3 *);
前面如果用 sqlite3_open 开启了一个数据库,结尾时不要忘了用这个函数关闭数据库。
下面给段简单的代码:
3
评论1
最新资源