- 浏览: 179715 次
- 来自: ...
文章分类
最新评论
-
fsword:
同事拿着试了一下,说是把第五步放到第二步之前就可以了
在windows下安装ruby1.9.2,rails3.0.3和DevKit--转 -
dothwinds:
[flash=200,200][/flash][url][/u ...
打包ruby or rails成exe(英文)
SQLite3 C/C++ 开发接口简介(API函数) 二(zt)
<script></script>标签:
知识/探索 |
2.2 执行 SQL 语句
typedef int
(*sqlite_callback)(void*,int,char**,
char**);
int sqlite3_exec(sqlite3*,
const char *sql, sqlite_callback, void*, char**);
sqlite3_exec 函数依然像它在SQLite2中一样承担着很多的工作. 该函数的第二个参数中可以编译和执行零个或多个SQL语句. 查询的结果返回给回调函数. 更多地信息可以查看API 参考.
在SQLite3里,sqlite3_exec一般是被准备SQL语句接口封装起来使用的.
typedef struct
sqlite3_stmt sqlite3_stmt;
int
sqlite3_prepare(sqlite3*, const char*, int, sqlite3_stmt**, const
char**);
int sqlite3_prepare16(sqlite3*,
const void*, int, sqlite3_stmt**, const
void**);
int
sqlite3_finalize(sqlite3_stmt*);
int
sqlite3_reset(sqlite3_stmt*);
sqlite3_prepare 接口把一条SQL语句编译成字节码留给后面的执行函数. 使用该接口访问数据库是当前比较好的的一种方法.
sqlite3_prepare() 处理的SQL语句应该是UTF-8编码的. 而sqlite3_prepare16() 则要求是UTF-16编码的. 输入的参数中只有第一个SQL语句会被编译. 第四个参数则用来指向输入参数中下一个需要编译的SQL语句存放的SQLite statement对象的指针, 任何时候如果调用 sqlite3_finalize() 将销毁一个准备好的SQL声明. 在数据库关闭之前,所有准备好的声明都必须被释放销毁. sqlite3_reset() 函数用来重置一个SQL声明的状态,使得它可以被再次执行.
SQL声明可以包含一些型如"?" 或 "?nnn" 或 ":aaa"的标记, 其中"nnn" 是一个整数,"aaa" 是一个字符串. 这些标记代表一些不确定的字符值(或者说是通配符),可以在后面用sqlite3_bind 接口来填充这些值. 每一个通配符都被分配了一个编号(由它在SQL声明中的位置决定,从1开始),此外也可以用 "nnn" 来表示 "?nnn" 这种情况. 允许相同的通配符在同一个SQL声明中出现多次, 在这种情况下所有相同的通配符都会被替换成相同的值. 没有被绑定的通配符将自动取NULL值.
int
sqlite3_bind_blob(sqlite3_stmt*, int, const void*, int n,
void(*)(void*));
int
sqlite3_bind_double(sqlite3_stmt*, int,
double);
int
sqlite3_bind_int(sqlite3_stmt*, int,
int);
int
sqlite3_bind_int64(sqlite3_stmt*, int, long long
int);
int
sqlite3_bind_null(sqlite3_stmt*, int);
int sqlite3_bind_text(sqlite3_stmt*, int, const char*, int n,
void(*)(void*));
int
sqlite3_bind_text16(sqlite3_stmt*, int, const void*, int n,
void(*)(void*));
int
sqlite3_bind_value(sqlite3_stmt*, int, const sqlite3_value*);
以上是 sqlite3_bind 所包含的全部接口,它们是用来给SQL声明中的通配符赋值的. 没有绑定的通配符则被认为是空值. 绑定上的值不会被sqlite3_reset()函数重置. 但是在调用了sqlite3_reset()之后所有的通配符都可以被重新赋值.
在SQL声明准备好之后(其中绑定的步骤是可选的), 需要调用以下的方法来执行:
int sqlite3_step(sqlite3_stmt*);
如果SQL返回了一个单行结果集,sqlite3_step() 函数将返回 SQLITE_ROW , 如果SQL语句执行成功或者正常将返回 SQLITE_DONE , 否则将返回错误代码. 如果不能打开数据库文件则会返回 SQLITE_BUSY . 如果函数的返回值是 SQLITE_ROW, 那么下边的这些方法可以用来获得记录集行中的数据:
const void
*sqlite3_column_blob(sqlite3_stmt*, int
iCol);
int
sqlite3_column_bytes(sqlite3_stmt*, int
iCol);
int
sqlite3_column_bytes16(sqlite3_stmt*, int
iCol);
int
sqlite3_column_count(sqlite3_stmt*);
const char *sqlite3_column_decltype(sqlite3_stmt *, int
iCol);
const void
*sqlite3_column_decltype16(sqlite3_stmt *, int
iCol);
double
sqlite3_column_double(sqlite3_stmt*, int
iCol);
int
sqlite3_column_int(sqlite3_stmt*, int
iCol);
long long int
sqlite3_column_int64(sqlite3_stmt*, int
iCol);
const char
*sqlite3_column_name(sqlite3_stmt*, int
iCol);
const void
*sqlite3_column_name16(sqlite3_stmt*, int
iCol);
const unsigned char
*sqlite3_column_text(sqlite3_stmt*, int
iCol);
const void
*sqlite3_column_text16(sqlite3_stmt*, int
iCol);
int
sqlite3_column_type(sqlite3_stmt*, int iCol);
sqlite3_column_count()函数返回结果集中包含的列数. sqlite3_column_count() 可以在执行了 sqlite3_prepare()之后的任何时刻调用. sqlite3_data_count()除了必需要在sqlite3_step()之后调用之外,其他跟sqlite3_column_count() 大同小异. 如果调用sqlite3_step() 返回值是 SQLITE_DONE 或者一个错误代码, 则此时调用sqlite3_data_count() 将返回 0 ,然而 sqlite3_column_count() 仍然会返回结果集中包含的列数.
返回的记录集通过使用其它的几个 sqlite3_column_***() 函数来提取, 所有的这些函数都把列的编号作为第二个参数. 列编号从左到右以零起始. 请注意它和之前那些从1起始的参数的不同.
sqlite3_column_type()函数返回第N列的值的数据类型. 具体的返回值如下:
#define
SQLITE_INTEGER 1
#define
SQLITE_FLOAT 2
#define
SQLITE_TEXT 3
#define SQLITE_BLOB
4
#define
SQLITE_NULL 5
sqlite3_column_decltype() 则用来返回该列在 CREATE TABLE 语句中声明的类型. 它可以用在当返回类型是空字符串的时候. sqlite3_column_name() 返回第N列的字段名. sqlite3_column_bytes() 用来返回 UTF-8 编码的BLOBs列的字节数或者TEXT字符串的字节数. sqlite3_column_bytes16() 对于BLOBs列返回同样的结果,但是对于TEXT字符串则按 UTF-16 的编码来计算字节数. sqlite3_column_blob() 返回 BLOB 数据. sqlite3_column_text() 返回 UTF-8 编码的 TEXT 数据. sqlite3_column_text16() 返回 UTF-16 编码的 TEXT 数据. sqlite3_column_int() 以本地主机的整数格式返回一个整数值. sqlite3_column_int64() 返回一个64位的整数. 最后, sqlite3_column_double() 返回浮点数.
不一定非要按照sqlite3_column_type()接口返回的数据类型来获取数据. 数据类型不同时软件将自动转换.
发表评论
-
DBDesigner使用笔记 --转,改
2011-08-18 10:26 1427DBDesigner使用笔记 表格之间的关系 ... -
DBDesigner4连接mysql出错的处理
2011-08-18 10:12 1361DBDesigner自mysql4.0之后没有更新对新版mys ... -
数据库设计经验谈-- 转
2011-08-01 17:42 784一个成功的管理系统,是由:[50% 的业务 + 50% ... -
两个数据库设计实例--转
2011-08-01 16:58 4353(注:摘自 http://blog. ... -
数据库设计三大范式应用实例剖析--转
2011-08-01 13:04 879引言 数据库的设计范式是数据库设计所需要满足的规范,满 ... -
SQLite Foreign Key Support --sqlite3.6.19--from sqlite.org
2011-07-30 12:30 1432Table Of Contents 1. Intro ... -
sqlite3 --sql命令简单介绍(zt)--转
2011-04-23 22:46 1721sqlite3 --sql命 ... -
SQLite3 C/C++ 开发接口简介(API函数)1(zt)--转
2011-04-23 22:44 1165SQLite3 C/C++ 开发接 ... -
SQLite适用的范围(zt)-转
2011-04-23 22:40 835SQLite适用的范围(zt) (2007-12- ... -
SQLite的体系结构简介(zt)--转
2011-04-23 22:39 1110SQLite的体系结构简 ... -
SQLite 第三版总览(简介)--转
2011-04-23 22:38 1317SQLite 第三版总览 SQLite 第三版主要 ... -
董淳光SQLITE3 使用总结(1)--转
2011-04-23 22:36 1032董淳光SQLITE3 使用总结(1) 转载 ... -
董淳光SQLITE3 使用总结(2)--转
2011-04-23 22:34 1342董淳光SQLITE3 使用 ... -
董淳光SQLITE3 使用总结(3)-转
2011-04-23 22:30 1031董淳光SQLITE3 使用总结(3) 转载 ... -
董淳光SQLITE3 使用总结(4)--转
2011-04-23 22:26 1222董淳光SQLITE3 使用总结(4) 转载 ... -
董淳光SQLITE3 使用总结(5)--转
2011-04-23 22:17 1444董淳光SQLITE3 使用总结(5) 转载 ... -
SQLite中如何用触发器执行取消和重做逻辑--转
2011-04-23 22:14 2041SQLite中如何用触发器执行取消和重做逻辑 转载 ... -
Oracle 常用函数
2008-12-04 12:08 783SQL中的单记录函数 1.ASCII 返回与指定的字符对应 ...
相关推荐
总的来说,SQLite3 C/C++开发接口提供了一个高效且灵活的平台,开发者可以通过这些接口实现对数据库的各种操作,包括创建、读取、更新和删除数据,以及执行复杂的SQL查询。虽然与旧版本存在不兼容性,但这些改变带来...
### SQLite3 C/C++开发接口详解 #### 一、引言 SQLite3是SQLite数据库引擎的一个重大升级,基于SQLite 2.8.13的基础上进行了革新,不仅在数据库格式和API方面进行了重大的不兼容改动,还引入了多项增强功能,如...
SQLite数据库的C/C++编程API手册,需要的朋友下
SQLite3是一种轻量级、开源的嵌入式数据库引擎,广泛应用于各种软件系统,尤其是C和C++开发的项目。SQLite3提供了丰富的C语言编程接口,使得开发者可以直接在应用程序中进行数据库操作,无需额外的服务器进程。这个...
### SQLite与C/C++编程简介 #### 一、引言 SQLite是一款轻量级的数据库管理系统,因其小巧、高效及可靠的特点,在嵌入式系统、移动应用开发以及桌面应用程序等领域得到了广泛的应用。本文旨在为读者提供一个清晰的...
SQLite3提供了一套C语言接口,允许开发者在C/C++程序中直接操作数据库。这些API函数包括数据库连接、数据库打开与关闭、SQL语句执行、事务处理等。 2. 数据库连接与关闭: 使用sqlite3_open()函数创建并打开一个...
SQLite 3 的 C/C++ 接口文档定义了与 SQLite 数据库交互的所有 C 语言函数和常量。这些接口不是教程性质的文档,而是提供了一种精确的参考手册,目的是帮助开发者理解如何使用 SQLite。对于初学者来说,建议首先阅读...
赠送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/C++ 开发接口详解 #### 1. 引言 SQLite3作为一款轻量级的关系型数据库管理系统,以其高效的性能、简洁的API和广泛的跨平台兼容性受到开发者的青睐。SQLite3相较于其前身SQLite 2.8.13,在功能上有了...
成功编译后,在指定的安装路径`/root/sqlite-3.6.5/build/bin`下会生成可执行文件`sqlite3`,在`/root/sqlite-3.6.5/build/include`下生成头文件`sqlite3.h`,在`/root/sqlite-3.6.5/build/lib`下生成静态库`...
sqlite3 数据库 的API接口函数以及编程
SQLite3 C 语言接口是 SQLite3 数据库管理系统提供的一种编程接口,允许 C 语言程序员使用 SQLite3 数据库。该接口提供了一系列函数和数据结构,用于创建、操作和管理 SQLite3 数据库。 快速入门 SQLite3 C 语言...
2. `sqlite3.h`: 这是一个头文件,包含了一系列的函数原型和数据结构定义,用于在C或C++代码中调用SQLite3的API。开发人员在源代码中#include这个头文件,就可以使用SQLite3提供的接口,例如打开数据库、执行SQL命令...
2. **SQLite3头文件(.h)**:这些头文件定义了C++接口,供开发者在代码中调用SQLite3的API。例如`sqlite3.h`包含了创建、打开、关闭数据库,执行SQL语句,处理结果集等所有必要的函数声明。 3. **SQLite3可执行...
赠送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文档:...
为了更好地集成到C++项目中,可以考虑对SQLite的C接口进行C++封装,例如使用智能指针管理数据库连接,以及封装更高级的接口来简化SQL语句的执行。这不仅可以提高代码的可读性和可维护性,还可以避免一些常见的错误,...
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);...
`CSqlite3`类应该封装SQLite3的C API,如`sqlite3_open()`, `sqlite3_exec()`, `sqlite3_close()`等,以提供更友好的C++接口。 为了保证线程安全,单例类的实例化通常会在第一次调用`getInstance()`时进行,使用...
在Windows操作系统下,如果想通过C++调用SQLite开发的时候,会用到资源中的内容。 共包括以下五个文件:sqlite3.lib sqlite3.h sqlite3.dll sqlite3.def mspdb60.dll 相关调用调用步骤和使用方法可见如下内容: ...
SQLite3是一款轻量级的开源数据库管理系统,它以C语言编写,可以嵌入到各种应用程序中,无需单独的服务器进程。在本主题中,我们关注的是SQLite3与C++的结合,即如何在C++程序中使用SQLite3进行数据存储和检索。 1....