sqlite3_exec函数的使用

sqlite3数据库是一个小型的关系型的数据库,以文件的方式存在,打开文件即是打开数据库,它小巧且功能强大,在嵌入式领域内使用很广.现在就介绍一下其中一个重要函数的使用:

int sqlite3_exec(sqlite3 *db, const char *sql, sqlite3_callback callback, void *,char **errmsg);

功能:执行sql语句

参数:

db:数据库句柄

sql:sql语句

callback:回调函数,每成功执行一次sql语句就执行一次callback函数

void *:给回调函数传的参数

errmsg:错误信息

回调函数的定义:

typedef int(*sqlite3_callback)(void *, int, char **, char **);

很明显这是一个函数指针,具体说明参见程序注释,现在贴出程序,程序注释比较详细,很容易看懂,我就不多说了.程序执行的前提是我在本目录下有一个提前创建好的有两个数据条目的名字叫environment的数据表在数据库文件db.db中

/**************************************************

* 文件名称:main.c

* 文件描述:测试sqlite3的sqlite3_exec函数的回调函数

* 文件作者:by Wang.J,in 2013.11.06

* 文件版本:1.0

* 修改记录:

**************************************************/

#include <stdio.h>

#include <stdlib.h>

#include <sqlite3.h>

#define DB_PATH "./db.db"

/*=======================================

* 函数名称:open_db

* 函数功能:打开数据库文件

* 函数参数:const char *path 数据库文件路径

* 返 回 值:成功 sqlite3*

失败 NULL

* 创 建 人:by Wang.J,in 2013.11.06

* 修改记录:

========================================*/

sqlite3 * open_db(const char *path)

{

sqlite3 *db = NULL;

int ret = 0;

ret = sqlite3_open(DB_PATH, &db);

if (SQLITE_OK != ret) {

printf("%s:数据库打开出错.\n错误原因:%s\n",

__FUNCTION__, sqlite3_errmsg(db));

sqlite3_close(db);

return NULL;

}

printf("%s:数据库打开成功\n", __FUNCTION__);

return db;

}

/*===================================================

* 函数名称:close_db

* 函数功能:关闭数据库文件

* 函数参数:sqlite3 *

* 返 回 值:void

* 创 建 人:by Wang.J,in 2013.11.06

* 修改记录:

====================================================*/

void close_db(sqlite3 *db)

{

if (NULL != db)

sqlite3_close(db);

printf("%s:数据库关闭成功\n", __FUNCTION__);

return;

}

/*======================================================

* 函数名称:callback

* 函数功能:sqlite3_exec的回调函数

* 函数参数:void *param 传递给callback回调函数的参数

对应于sqlite3_exec函数的第四个参数

int f_num 查找到的记录中包含的字段数目

char **f_value 包含查找到每个记录的字段值

char **f_name 包含查找到每个记录的字段名称

* 返 回 值:成功返回0

失败返回-1

* 创 建 人:by Wang.J,in 2013.11.06

* 修改记录:

=======================================================*/

int callback(void *param, int f_num, char **f_value, char **f_name)

{

printf("%s:这是回调函数!\n", __FUNCTION__);

return 0;

}

int main(void)

{

char sql[512];

sqlite3 *db = NULL;

char *err_msg;

int ret = 0;

printf("函数开始\n");

sprintf(sql, "SELECT * FROM environment;");

db = open_db(DB_PATH);

ret = sqlite3_exec(db, sql, callback, NULL, &err_msg);

printf("函数返回值:%d\n", ret);

if (0 != ret) {

//printf("函数执行失败\n");

perror("函数执行失败\n");

return -1;

}

close_db(db);

printf("函数结束\n");

return 0;

}

程序执行结果

结果为预期结果.

现在看看给回调函数传参:

/**************************************************

* 文件名称:main.c

* 文件描述:测试sqlite3的sqlite3_exec函数的回调函数

* 文件作者:by Wang.J,in 2013.11.06

* 文件版本:1.0

* 修改记录:

**************************************************/

#include <stdio.h>

#include <stdlib.h>

#include <sqlite3.h>

#define DB_PATH "./db.db"

/*=======================================

* 函数名称:open_db

* 函数功能:打开数据库文件

* 函数参数:const char *path 数据库文件路径

* 返 回 值:成功 sqlite3*

失败 NULL

* 创 建 人:by Wang.J,in 2013.11.06

* 修改记录:

========================================*/

sqlite3 * open_db(const char *path)

{

sqlite3 *db = NULL;

int ret = 0;

ret = sqlite3_open(DB_PATH, &db);

if (SQLITE_OK != ret) {

printf("%s:数据库打开出错.\n错误原因:%s\n",

__FUNCTION__, sqlite3_errmsg(db));

sqlite3_close(db);

return NULL;

}

printf("%s:数据库打开成功\n", __FUNCTION__);

return db;

}

/*===================================================

* 函数名称:close_db

* 函数功能:关闭数据库文件

* 函数参数:sqlite3 *

* 返 回 值:void

* 创 建 人:by Wang.J,in 2013.11.06

* 修改记录:

====================================================*/

void close_db(sqlite3 *db)

{

if (NULL != db)

sqlite3_close(db);

printf("%s:数据库关闭成功\n", __FUNCTION__);

return;

}

/*======================================================

* 函数名称:callback

* 函数功能:sqlite3_exec的回调函数

* 函数参数:void *param 传递给callback回调函数的参数

对应于sqlite3_exec函数的第四个参数

int f_num 查找到的记录中包含的字段数目

char **f_value 包含查找到每个记录的字段值

char **f_name 包含查找到每个记录的字段名称

* 返 回 值:成功返回0

失败返回-1

* 创 建 人:by Wang.J,in 2013.11.06

* 修改记录:

=======================================================*/

int callback(void *param, int f_num, char **f_value, char **f_name)

{

printf("%s:这是回调函数!\n", __FUNCTION__);

printf("%s:回调函数的参数内容:%s\n\n", __FUNCTION__, (char *)param);

return 0;

}

int main(void)

{

char sql[512];

sqlite3 *db = NULL;

char *err_msg;

int ret = 0;

printf("函数开始\n");

sprintf(sql, "SELECT * FROM environment;");

db = open_db(DB_PATH);

ret = sqlite3_exec(db, sql, callback, "回调函数参数,来自主程序", &err_msg);

printf("函数返回值:%d\n", ret);

if (0 != ret) {

//printf("函数执行失败\n");

perror("函数执行失败\n");

return -1;

}

close_db(db);

printf("函数结束\n");

return 0;

}

执行结果:

依旧没问题.

OK!基本就这些了.

sqlite3_exec函数的使用的更多相关文章

  1. 数据库(SQLITE3函数总结): sqlite3_open, sqlite3_exec, slite3_close,sqlite3_prepare_v2,sqlite3_column_text,

    Sqlite3 的确非常好用.小巧.速度快.近期研究它,有一些收获,这里把我对 sqlite3 的研究列出来,以备忘记. 导入SQLLite library并引入头文件. libsqlite3.dyl ...

  2. sqlite入门基础(一):sqlite3_open,sqlite3_exec,slite3_close

    打开数据库链接sqlite3_open用法 原型: int sqlite3_open( const char *filename, /* Database filename (UTF-8) */ sq ...

  3. SQLite3 C/C++ 开发接口简介(API函数)

    from : http://www.sqlite.com.cn/MySqlite/5/251.Html 1.0 总览 SQLite3是SQLite一个全新的版本,它虽然是在SQLite 2.8.13的 ...

  4. SQLite3开发接口函数详解

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

  5. 数据库函数:sqlite3_exec() SQL语句

    函数:sqlite3_exec(),称为便捷函数,封装了好多任务. 函数声明: int  sqlite3_exec( sqlite   * , const  char * sql , sqlite_c ...

  6. SQLITE3 使用总结(直接使用C函数)

    转载网址:http://blog.chinaunix.net/uid-8447633-id-3321394.html 前序: Sqlite3 的确很好用.小巧.速度快.但是因为非微软的产品,帮助文档总 ...

  7. sqlite3入门之sqlite3_open,sqlite3_exec,slite3_close

    sqlite3_open sqlite3_open函数原型: int sqlite3_open( const char *filename, /* Database filename (UTF-8) ...

  8. 【原】FMDB源码阅读(二)

    [原]FMDB源码阅读(二) 本文转载请注明出处 -- polobymulberry-博客园 1. 前言 上一篇只是简单地过了一下FMDB一个简单例子的基本流程,并没有涉及到FMDB的所有方方面面,比 ...

  9. iOS开发系列--数据存取

    概览 在iOS开发中数据存储的方式可以归纳为两类:一类是存储为文件,另一类是存储到数据库.例如前面IOS开发系列-Objective-C之Foundation框架的文章中提到归档.plist文件存储, ...

随机推荐

  1. jquery判断checkbox是否选中及改变checkbox状态[转]

    jquery判断checked的三种方法: .attr('checked): //看版本1.6+返回:”checked”或”undefined” ;1.5-返回:true或false .prop('c ...

  2. C#里WinForm开发中如何实现控件随窗体大小的改变而自动适应其改变(转)

    在设计可供用户调整大小的窗体时,如何实现该窗体上的控件也应能正确地随窗体的改变而自动调整大小并且能重新定位?此时就要借助控件的.Anchor属性.Anchor属性定义控件的定位点位置.当控件锚定到某个 ...

  3. C API 连接MYSQL

    #include <iostream> #include <mysql.h> #include <string> #include <assert.h> ...

  4. menu({postion:{my:"left top"},at:"right bottom"})里的my与at会冲突吗

    my(默认值:"center")类型:String描述:定义被定位元素上对准目标元素的位置:"horizontal vertical" 对齐方式.一个单一的值, ...

  5. 动态添加js文件.

    方法一: $.getScript(url,callback); 这个方法是对$.ajax({ })的封装.默认是异步的而且是带有缓存的. 缓存对于用户来说,是个好东西,但是对于开发者来说可就是日了狗的 ...

  6. abap case when 例子

    DATA: gv_1 TYPE c. DATA: gv_2 TYPE i. gv_2 = 60. IF gv_2 >= 0 AND gv_2 < 60 . gv_1 = 'A'. ELSE ...

  7. Maven依赖范围及依赖传递

    一: 依赖范围scope 共5种,compile (编译).test (测试).runtime (运行时).provided.system 不指定,则依赖范围默认为compile. compile:编 ...

  8. Oracle Grid Infrastructure: Understanding Split-Brain Node Eviction (文档 ID 1546004.1)

    In this Document   Purpose   Scope   Details   What does "split brain" mean?   Why is this ...

  9. Caught exception while loading file struts-default.xml 错误

    严重: Exception starting filter struts2 Caught exception while loading file struts-default.xml - [unkn ...

  10. Python实现顺时钟回形矩阵

    无意间在网上看到了一个面试题是,写出一个回形矩阵.实现的效果大致如下: [ 1,   2,   3,   4, 5] [16, 17, 18, 19, 6] [15, 24, 25, 20, 7] [ ...