sqlite3_exec函数的使用
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中
#include <stdio.h>
#include <stdlib.h>
#include <sqlite3.h>
#define DB_PATH "./db.db"
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;
}
void close_db(sqlite3 *db)
{
if (NULL != db)
sqlite3_close(db);
printf("%s:数据库关闭成功\n", __FUNCTION__);
return;
}
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;
}
程序执行结果
结果为预期结果.
现在看看给回调函数传参:
#include <stdio.h>
#include <stdlib.h>
#include <sqlite3.h>
#define DB_PATH "./db.db"
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;
}
void close_db(sqlite3 *db)
{
if (NULL != db)
sqlite3_close(db);
printf("%s:数据库关闭成功\n", __FUNCTION__);
return;
}
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!基本就这些了.
免责声明:
① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。
② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341