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

相关推荐
不总是10 小时前
[2026最新] Windows 免安装版 MySQL 8 详细安装配置教程(ZIP 压缩包版)
数据库·windows·mysql
摇滚侠10 小时前
Java 零基础全套教程,反射机制,笔记 187-188
java·开发语言·笔记
超梦dasgg10 小时前
Java 生产环境第三方对接安全保障方案
java·开发语言·安全
tedcloud12310 小时前
DBX部署教程:打造支持AI SQL助手的数据库管理环境
数据库·人工智能·sql
野生技术架构师10 小时前
我有个大胆的想法,用 PostgreSQL 代替 Redis
数据库·redis·postgresql
cfm_291410 小时前
Redis ZSet 有序集合详解
数据库·redis·缓存
瀚高PG实验室10 小时前
V4.5.6.1授予普通用户监控类系统表及视图的查询权限
数据库·瀚高数据库
日月云棠11 小时前
9 Double 与 Float —— IEEE 754 浮点数在 Java 中的实现
java·后端
Refrain_zc11 小时前
Android 二维码登录轮询机制:从扫码到登录的完整客户端实现
java
z落落11 小时前
C#参数区别
java·算法·c#