前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >sqlite3_exec函数的使用

sqlite3_exec函数的使用

作者头像
py3study
发布2020-01-08 18:47:42
2.9K0
发布2020-01-08 18:47:42
举报
文章被收录于专栏:python3python3

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中

clip_image002
clip_image002
代码语言:javascript
复制
/**************************************************

* 文件名称: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;

}

程序执行结果

clip_image004
clip_image004

结果为预期结果.

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

代码语言:javascript
复制
/**************************************************

* 文件名称: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;

}

执行结果:

clip_image006
clip_image006

依旧没问题.

OK!基本就这些了.

本文参与 腾讯云自媒体分享计划,分享自作者个人站点/博客。
原始发表:2019-09-02 ,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体分享计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
相关产品与服务
数据库
云数据库为企业提供了完善的关系型数据库、非关系型数据库、分析型数据库和数据库生态工具。您可以通过产品选择和组合搭建,轻松实现高可靠、高可用性、高性能等数据库需求。云数据库服务也可大幅减少您的运维工作量,更专注于业务发展,让企业一站式享受数据上云及分布式架构的技术红利!
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档