SQLite中如何用api操作blob类型的字段

鉴客 发布于 2010/05/18 11:44
阅读 2K+
收藏 0

在实际的编程开发当中我们经常要处理一些大容量二进制数据的存储,如图片或者音乐等等。对于这些二进制数据(blob字段)我们不能像处理普通的文本那样 简单的插入或者查询,为此SQLite提供了一组函数来处理这种BLOB字段类型。下面的代码演示了如何使用这些API函数。

首先我们要建立一个数据库:

  1. sqlite3_exec(db, "CREATE TABLE list (fliename varchar(128) UNIQUE, fzip blob);", 0, 0, &zErrMsg);


本例中假设要保存mmmm.rar文件内容到fzip里,由于mmmm.rar是一个二进制文件,所以要在使用insert语句时先用号 代替

  1. sqlite3_prepare(db, "insert into list values ('mmmm.rar',?);", -1, &stat, 0);
  2. FILE *fp;
  3. long filesize = 0;
  4. char * ffile;
  5. fp = fopen("mmmm.rar""rb");
  6. if(fp != NULL)
  7. {
  8.     //计算文件的大小
  9.     fseek(fp, 0, SEEK_END);
  10.     filesize = ftell(fp);
  11.     fseek(fp, 0, SEEK_SET);
  12.     //读取文件
  13.     ffile = new char[filesize+1];
  14.     size_t sz = fread(ffile, sizeof(char), filesize+1, fp);
  15.     fclose(fp);
  16. }
  17. //将文件数据绑定到insert语句中,替换 “?”部分
  18. sqlite3_bind_blob(stat, 1, ffile, filesize, NULL);
  19. //执行绑定之后的SQL语句
  20. sqlite3_step(stat);

这时数据库当中已经有了一条包含BLOB字段的数据。接下来我们要读取这条数据:

  1. //选取该条数据
  2. sqlite3_prepare(db, "select * from list;", -1, &stat, 0);
  3. sqlite3_step(stat);
  4. //得到纪录中的BLOB字段
  5. const void * test = sqlite3_column_blob(stat, 1);
  6. //得到字段中数据的长度
  7. int size = sqlite3_column_bytes(stat, 1);
  8. //拷贝该字段
  9. sprintf(buffer2, "%s", test);


此时可以将buffer2写入到文件当中,至此BLOB数据处理完毕。

加载中
0
s
sevencat

blob类型其实就是对\0,\r\n之类的进行转码了。

返回顶部
顶部