C语言使用sqlite3接口

C语言调用sqlite3,执行
ret =sqlite3_exec(pDb,"SELECT id FROM user",NULL,NULL,&errmsg);
我要怎么得到选择出来的id,ret好像只是一个返回状态。急等

阅读 3.2k
1 个回答
int record_row(void *params,int n_column,char **column_value,char **column_name){
    int i;
    for(i=0;i<n_column;i++){
        printf("\t%s",column_value[i]);
    }
    printf("\n");
    return 0;
}

int main(){
    ret = sqlite3_exec(pDb,"SELECT id FROM user",record_row,NULL,&errmsg);
    if(ret != SQLITE_OK){
        fprintf(stderr,"query SQL error: %s\n",errmsg);
    }
}

大概是这样了~
sqlite每返回一行记录,就会调用record_row
你可以把printf 改成写入数组 或 文件之类。

撰写回答
你尚未登录,登录后可以
  • 和开发者交流问题的细节
  • 关注并接收问题和回答的更新提醒
  • 参与内容的编辑和改进,让解决方法与时俱进