`

SQLite3 C/C++ 开发接口简介(API函数)1(zt)--转

阅读更多

 

SQLite3 C/C++ 开发接口简介(API函数)1(zt)

<script type="text/javascript"></script>标签:

知识/探索

 
<!-- 正文开始 -->

1.0 总览

SQLite3是SQLite一个全新的版本,它虽然是在SQLite 2.8.13的代码基础之上开发的,但是使用了和之前的版本不兼容的数据库格式和API. SQLite3是为了满足以下的需求而开发的:

  • 支持UTF-16编码.
  • 用户自定义的文本排序方法.
  • 可以对BLOBs字段建立索引.

因此为了支持这些特性我改变了数据库的格式,建立了一个与之前版本不兼容的3.0版. 至于其他的兼容性的改变,例如全新的API等等,都将在理论介绍之后向你说明,这样可以使你最快的一次性摆脱兼容性问题.

3.0版的和2.X版的API非常相似,但是有一些重要的改变需要注意. 所有API接口函数和数据结构的前缀都由"sqlite_"改为了"sqlite3_". 这是为了避免同时使用SQLite 2.X和SQLite 3.0这两个版本的时候发生链接冲突.

由于对于C语言应该用什么数据类型来存放UTF-16编码的字符串并没有一致的规范. 因此SQLite使用了普通的void* 类型来指向UTF-16编码的字符串. 客户端使用过程中可以把void*映射成适合他们的系统的任何数据类型.

2.0 C/C++ 接口

SQLite 3.0一共有83个API函数,此外还有一些数据结构和预定义(#defines). (完整的API介绍请参看另一份文档.) 不过你们可以放心,这些接口使用起来不会像它的数量所暗示的那么复杂. 最简单的程序仍然使用三个函数就可以完成: sqlite3_open(), sqlite3_exec(), 和 sqlite3_close(). 要是想更好的控制数据库引擎的执行,可以使用提供的sqlite3_prepare()函数把SQL语句编译成字节码,然后在使用 sqlite3_step()函数来执行编译后的字节码. 以sqlite3_column_开头的一组API函数用来获取查询结果集中的信息. 许多接口函数都是成对出现的,同时有UTF-8和UTF-16两个版本. 并且提供了一组函数用来执行用户自定义的SQL函数和文本排序函数.

2.1 如何打开关闭数据库

 typedef struct sqlite3 sqlite3;
int sqlite3_open(const char*, sqlite3**);
int sqlite3_open16(const void*, sqlite3**);
int sqlite3_close(sqlite3*);
const char *sqlite3_errmsg(sqlite3*);
const void *sqlite3_errmsg16(sqlite3*);
int sqlite3_errcode(sqlite3*);
 

sqlite3_open() 函数返回一个整数错误代码,而不是像第二版中一样返回一个指向sqlite3结构体的指针. sqlite3_open() 和 sqlite3_open16() 的不同之处在于sqlite3_open16() 使用UTF-16编码(使用本地主机字节顺序)传递数据库文件名. 如果要创建新数据库, sqlite3_open16() 将内部文本转换为UTF-16编码, 反之sqlite3_open() 将文本转换为UTF-8编码.

打开或者创建数据库的命令会被缓存,直到这个数据库真正被调用的时候才会被执行. 而且允许使用PRAGMA声明来设置如本地文本编码或默认内存页面大小等选项和参数.

sqlite3_errcode() 通常用来获取最近调用的API接口返回的错误代码. sqlite3_errmsg() 则用来得到这些错误代码所对应的文字说明. 这些错误信息将以 UTF-8 的编码返回,并且在下一次调用任何SQLite API函数的时候被清除. sqlite3_errmsg16() 和 sqlite3_errmsg() 大体上相同,除了返回的错误信息将以 UTF-16 本机字节顺序编码.

SQLite3的错误代码相比SQLite2没有任何的改变,它们分别是:

#define SQLITE_OK 0 
#define SQLITE_ERROR 1 
#define SQLITE_INTERNAL 2 
#define SQLITE_PERM 3 
#define SQLITE_ABORT 4 
#define SQLITE_BUSY 5 
#define SQLITE_LOCKED 6 
#define SQLITE_NOMEM 7 
#define SQLITE_READONLY 8 
#define SQLITE_INTERRUPT 9 
#define SQLITE_IOERR 10 
#define SQLITE_CORRUPT 11 
#define SQLITE_NOTFOUND 12 
#define SQLITE_FULL 13 
#define SQLITE_CANTOPEN 14 
#define SQLITE_PROTOCOL 15 
#define SQLITE_EMPTY 16 
#define SQLITE_SCHEMA 17 
#define SQLITE_TOOBIG 18 
#define SQLITE_CONSTRAINT 19 
#define SQLITE_MISMATCH 20 
#define SQLITE_MISUSE 21 
#define SQLITE_NOLFS 22 
#define SQLITE_AUTH 23 
#define SQLITE_ROW 100 
#define SQLITE_DONE 101 

 

分享到:
评论

相关推荐

    SQLite3 C/C++ 开发接口简介(API函数)--没有功劳也有苦劳吧

    SQLite3 C/C++ 开发接口简介(API函数) 1.0 总览 SQLite3是SQLite一个全新的版本,它虽然是在SQLite 2.8.13的代码基础之上开发的,但是使用了和之前的版本不兼容的数据库格式和API. SQLite3是为了满足以下的需求而...

    SQLite-C/C++编程API手册

    SQLite数据库的C/C++编程API手册,需要的朋友下

    sqlite3_c/c++ 开发接口

    详细人绍了C/C++中使用SQLITE的接口函数

    SQlite3中级篇(C/C++编程接口) 源代码

    SQlite3中级篇(C/C++编程接口) 源代码

    Programming SQLite with C/C++

    从一本300多页的SQLITE书籍中摘取C/C++编程的部分,另从SQLite官网上提取了一份简洁实用的教程,做成PDF档,共26页,快速领会SQLite在C/C++下编程,不浪费您宝贵时间。

    SQLite 3的C∕C++ 接口

    相当于SQLite的一个C/C++接口的详单,转自http://www.sqlite.org/capi3ref.html 英文好的朋友可以参考

    sqlite3 数据库api函数

    sqlite3 数据库 的API接口函数以及编程

    SQlite3高级应用篇(C/C++编程接口) 源代码

    SQlite3高级应用篇(C/C++编程接口)

    SQLite – C/C++

    以下是重要的 C&C++ / SQLite 接口程序,可以满足您在 C/C++ 程序中使用 SQLite 数据库的需求。如果您需要了解更多细节,请查看 SQLite 官方文档。 序号 API & 描述 1 sqlite3_open(const char *filename, ...

    sqlite-jdbc-3.34.0-API文档-中文版.zip

    赠送jar包:sqlite-jdbc-3.34.0.jar; 赠送原API文档:sqlite-jdbc-3.34.0-javadoc.jar; 赠送源代码:sqlite-jdbc-3.34.0-sources.jar; 赠送Maven依赖信息文件:sqlite-jdbc-3.34.0.pom; 包含翻译后的API文档:...

    sqlite3(c++调用SQLite接口函数时会用到)

    在Windows操作系统下,如果想通过C++调用SQLite开发的时候,会用到资源中的内容。 共包括以下五个文件:sqlite3.lib sqlite3.h sqlite3.dll sqlite3.def mspdb60.dll 相关调用调用步骤和使用方法可见如下内容: ...

    sqlite-jdbc-3.15.1-API文档-中文版.zip

    赠送jar包:sqlite-jdbc-3.15.1.jar; 赠送原API文档:sqlite-jdbc-3.15.1-javadoc.jar; 赠送源代码:sqlite-jdbc-3.15.1-sources.jar; 赠送Maven依赖信息文件:sqlite-jdbc-3.15.1.pom; 包含翻译后的API文档:...

    sqlite3增删改查C++接口实现

    int MYDLL open_db(); int MYDLL create_table(); int MYDLL drop_table(); int MYDLL insert_data(int id, char *name, int age); int MYDLL search_data(int id); int MYDLL search_data(char *name);...

    SQLite的C++接口

    一.准备工作 2 二.核心对象和接口 2 1.核心对象 2 2.核心接口 2 1.sqlite3_open 2 2.sqlite3_close 2 3.sqlite3_exec 2 4.sqlite_errmsg 3 三.示例代码-C语言 4 1.链接数据库student.db...四.SQLite接口的C++封装 8

    sqlite3 C语言接口

    讲解sqlite3的C语言接口,包括预处理语法

    SQLite3 的简单封装

    SQLite3 的简单封装,实现了最基本的增删查改, 里面有简单的数据库文件 data.s3db可供测试, /* // func name: open // param----begin----param // file : 文件名,包括路径 // param-----end-----param // ...

    SQLite3资料C++

    SQLiteSpy_1.8.5 数据库查看UI程序 :查看SQLIte3 数据库的UI小程序 _SQLite权威指南.pdf SQLite学习手册_中文全本.pdf CppSQLite3U国外牛人的sqlite封装.zip C++封装类使用方法:...

    c/c++ sqlite3示例

    c++的sqlite3接口.如果是c语言的话把函数参数传引用的地方的引用去掉即可,返回时返回指针就OK了.在linux环境下调试OK.里面有个示例Makefile及相应的源码.Makefile要根据个人机器上的sqlite3的头文件及动态库的存放...

    sqlite .net驱动程序for VS2005-2013

    sqlite .net驱动程序for VS2005-2013 官方链接 http://system.data.sqlite.org/index.html/doc/trunk/www/downloads.wiki

    SQLite个人总结

    本人也是依照这些文档入门的,这些文档介绍了SQLite的简单使用、SQLite3 C/C++ 开发接口简介(API函数)、在VC下使用SQLite等等,对新手入门很有帮助。

Global site tag (gtag.js) - Google Analytics