SQLite3中的callback回调函数注意的细节

调用

cpp 复制代码
sqlite3_exec(sqlite3*, const char *sql, sqlite_callback, void *data, char **errmsg)

该例程提供了一个执行 SQL 命令的快捷方式,
SQL 命令由 sql 参数提供,可以由多个 SQL 命令组成。
在这里,

第一个参数 sqlite3 是打开的数据库对象,
第二个 sqlite_callback 是一个回调,data 作为其第一 个参数,
errmsg 将被返回用来获取程序生成的任何错误。
sqlite3_exec() 程序解析并执行由 sql 参数所给的每个命令,直到字符串结束或者遇到错误为止。

======================================================================

cpp 复制代码
 int callback(void *arg, int column_size, char *column_value[], char *column_name[])
 参数分析:void *arg:是sqlite3_exec函数的第四个参数 
column_size:数据库的字段数(学号,名字,分数,性别。共四个字段数) 
column_value[]:列的值() (对应的字段数的值是多少)
column_name:字段名字(学号的字段名为ID,名字的字段名为Name,以此类推)

========================================================================

数据库(共3条数据,每条数据都有4个字段):

=========================================================================

return 0

不加return 0(写return 1 也只返回一次 )

测试实例:

cpp 复制代码
#include <stdio.h>
#include <sqlite3.h>
int callback(void *arg, int column_size, char *column_value[], char
*column_name[])
{
    int i;
    printf("arg=%s\n",(char *)arg);

    for(i=0;i<column_size;i++){
    printf("%s = %s\n", column_name[i], column_value[i]);
    }
    printf("=======================\n");
    return 0;//必须返回0,这样数据库中有多少条数据,这个回调函数就会被调用多少次
}
int main(char argc, char **argv)
{
    sqlite3 *db;
    char *errorMes = NULL;
    int ret;
    if(argc < 2){
    printf("Usage: %s xxx.db\n",argv[0]);
    return -1;
}
    if( (ret = sqlite3_open(argv[1],&db)) == SQLITE_OK){
    printf("open %s success\n",argv[1]);
}else{
    printf("error:%s,%d\n",sqlite3_errmsg(db),ret);
    if(ret == 14){
    printf("permission den\n");
    }
return -1;
}
//sqlite3_exec(sqlite3*, const char *sql, sqlite_callback, void *data, char
**errmsg)
    sqlite3_exec(db, "select * from stu;",callback, "content of sql:",
&errorMes);//errorMes may sigment error!
    sqlite3_close(db);
    printf("done\n");
    return 0;
}

加了return 0;

不加return 0

相关推荐
YongCheng_Liang5 分钟前
MySQL 高级特性深度解析:从索引优化到高可用架构
运维·数据库·mysql
没有bug.的程序员10 分钟前
HashMap 源码深度剖析:红黑树转换机制与高并发性能陷阱
java·性能优化·并发编程·源码分析·红黑树·hashmap·技术深度
yaoxin52112320 分钟前
294. Java Stream API - 对流进行归约
java·开发语言
曹轲恒21 分钟前
Thread.sleep() 方法详解
java·开发语言
Coder_Boy_23 分钟前
基于SpringAI的在线考试系统-考试模块前端页面交互设计及优化
java·数据库·人工智能·spring boot
dblens 数据库管理和开发工具26 分钟前
QueryNote V1.2 发布:从个人思考空间,迈向团队协作与内容交付
数据库·dblens
小小仙。27 分钟前
IT自学第十九天
java·开发语言
悟空码字28 分钟前
SpringBoot集成Hera,分布式应用监控与追踪解决方案
java·springboot·编程技术·后端开发·hera
砚边数影31 分钟前
Java基础强化(三):多线程并发 —— AI 数据批量读取性能优化
java·数据库·人工智能·ai·性能优化·ai编程
悟能不能悟35 分钟前
.jrxml和.jasper文件是什么关系
java