#include <stdio.h>
#include <sqlite3.h>
static int callback(void *NotUsed, int argc, char **argv, char **azColName)
/**callback的第二个参数传入的是查询结果的列数,第三个参数传入的是包含各列的值的string数组
,第四个参数传入的是各列的列字。callback可以是NULL。*/
{
int i;
for(i=0; i<argc; i++){
printf("%s = %s\n", azColName[i], argv[i] ? argv[i] : "NULL");
}
printf("\n");
return 0;
}
int main(int argc, char **argv){
sqlite3 *db;
char *zErrMsg = 0;
int rc;
if( argc!=3 ){
fprintf(stderr, "Usage: %s DATABASE SQL-STATEMENT\n", argv[0]);
exit(1);
}
rc = sqlite3_open(argv[1], &db);
if( rc ){
fprintf(stderr, "Can't open database: %s\n", sqlite3_errmsg(db));
sqlite3_close(db);
exit(1);
}
rc = sqlite3_exec(db,argv[2],callback,0,&zErrMsg);
///rc = sqlite3_exec(打开的数据库,SQL语句,调用callback函数,该void *作为callback的第一个参
数传给callback, &zErrMsg);
/**
该函数返回SQLITE_OK,则表明执行成功。
返回SQLITE_BUSY,则表明数据库被锁或忙(这种情况可以用 sqlite3_busy_handler() 和
sqlite3_busy_timeout() 来改进)。
callback函数通常返回0;如果返回非0值,查询中止,跳过其后SQL语句并且sqlite3_exec()返回
SQLITE_ABORT。
当在执行SQL语句发生错误(不是在执行callback)时,错误信息会写入用malloc()获取的内存,
*errmsg指向该内存。该内存应该由callback负责释放,可以通过调用sqlite3_free()。如果
errmsg==NULL,则表明没有错误信息。
什么是void指针
void指针一般称为“通用指针”或“泛指针”。void指针可以很容易地转换成其它数据类型的指针。
例如在为一个指针分配内存空间的时候:
int *p;
p=(int *)malloc(......);
函数malloc的返回值是void类型,通过在前面加上一个带括号的int*就把void*类型转换成了int*类型
。
*/
if( rc!=SQLITE_OK )
{
fprintf(stderr, "SQL error: %s\n", zErrMsg);
}
sqlite3_close(db);
return 0;
}
2005.8.1-在程序中用SQlite.txt