sqlite3_exec

函数sqlite3_exec(),称为便捷函数,封装了好多任务。

函数声明:

int sqlite3_exec( sqlite *,const char * sql,sqlite_callback,void *data,char ** errmmsg) ; 其中 sqlite* 表示打开的数据库

sql 为执行的sql语句;

callback回调函数

void *data为回调函数的第一个参数指向提供给回调函数的应用程序特定的数据,也是回调函数的第一个参数; errmsg 为错误信息,是指向错误消息字符串的指针 。


sqlite_exec() 有两个错误消息来源,返回值和可读的字符串errmsg。

注意:如果提供 了errmsg,用来创建错误消息的内存是在堆上分布的。 故在调用后,应该检查一下是否为null值,如果有错误发生,使用sqlite3_free()释放errmsg占用的内存。

在简单命令中使用sqlite3_ exec( ),实例代码

intmain(intargc,char**argv)
{
sqlite3*db;
char*zErr;
ntrc;
char*sql;
rc=sqlite3_open_v2("test.db",&db);
if(rc){
fprintf(stderr,"Can'topendatabase:%s\n",sqlite3_errmsg(db));
sqlite3_close(db);
exit(1);
}
sql="createtableepisodes(idint,nametext)";
rc=sqlite3_exec(db,sql,NULL,&zErr);

if(rc!=sqlITE_OK){
if(zErr!=NULL){
fprintf(stderr,"sqlerror:%s\n",zErr);
sqlite3_free(zErr);
}
}

sql="insertintoepisodesvalues(10,'thedinnerparty')";
rc=sqlite3_exec(db,&zErr);

sqlite3_close(db);
return0;
}

回调函数的声明:

typedef int ( * sqlite3_callback ) (void *,int,char **,char ** );其中void *是为sqlite3_exec()第四个参数提供的数据,int代表字段的数目,char** 便是行中字段名称的字符串的数组,char**表示字段ing成的字符串数组。

sqlite3_exec( )允许执行一批命令,并可以通过回调接口收集所有的返回数据。

相关文章

安装 在Windows上安装SQLite。 访问官网下载下Precompliled Binaries for Windows的两个压缩包。 创建s...
一、安装 下载地址:http://www.sqlite.org/download.html 将Precompiled Binaries for Windows下的包下...
实例: 会员信息管理 功能:1.查看数据库 2.清空数据库 3.增加会员 4.删除会员 5.更新会员 6.查找会员  ...
关于SQLite SQLite是一个轻量的、跨平台的、开源的数据库引擎,它的在读写效率、消耗总量、延迟时间和整...