大佬教程收集整理的这篇文章主要介绍了sqlite3_exec,大佬教程大佬觉得挺不错的,现在分享给大家,也给大家做个参考。
函数声明:
int sqlite3_exec( sqlite *,const char * sql,sqlite_callback,void *data,char ** errmmsg) ; 其中 sqlite* 表示打开的数据库; sql 为执行的sql语句;callBACk回
调函数;void *data为回调函数的第一个参数指向提供给回调函数的应用程序特定的数据,也是回调函数的第一个参数; errmsg 为错误信息,是指向错误消息字符串的指针 。
@R_649_5607@exec() 有两个错误消息来源,返回值和可读的字符串errmsg。
注意:如果提供 了errmsg,用来创建错误消息的内存是在堆上分布的。 故在调用后,应该检查一下是否为null值,如果有错误发生,使用SQLite3_free()释放errmsg占用的内存。
在简单命令中使用SQLite3_ exec( ),实例代码:
int main(int argc,char ** argv)
sqlite3 *db;
char *zErr ;
nt rc ;
char *sql;
rc = sqlite3_open_v2( "test.db",@R_581_4616@;
fprintf(stderr," Can't open database :%s\n",sqlite3_errmsg(db));
exit(1);
}
sql="create table episodes(ID int,@R_345_4687@t ) ";
rc = sqlite3_exec(db,sql,NulL,&zErr ) ;
fprintf( stderr," sql error : %s\n ",zErr);
sqlite3_free(zErr) ;
}
}
sql = "insert into episodes values ( 10,'the dinner party ' )";
rc = sqlite3_exec(db,&zErr);
sqlite3_close(db) ;
return 0 ;
}
回调函数的声明:
typedef int ( * sqlite3_callback ) (void *,int,char **,char ** );其中void *是为sqlite3_exec()第四个参数提供的数据,int代表字段的数目,char** 便是行中字段名称的字符串的数组,char**表示字段ing成的字符串数组。
sqlite3_exec( )允许执行一批命令,并可以通过回调接口收集所有的返回数据。
以上是大佬教程为你收集整理的sqlite3_exec全部内容,希望文章能够帮你解决sqlite3_exec所遇到的程序开发问题。
如果觉得大佬教程网站内容还不错,欢迎将大佬教程推荐给程序员好友。
本图文内容来源于网友网络收集整理提供,作为学习参考使用,版权属于原作者。
如您有任何意见或建议可联系处理。小编QQ:384754419,请注明来意。