在路上...

导航

公告
 

#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

posted on 2005-08-01 19:34 AK747 阅读(...) 评论(...) 编辑 收藏