当前位置: 首页 > news >正文

SQLite3使用接口写入二进制文件

使用接口的方式写入二进制文件 ,有二种方案。

一、全部文件 一次性写下到数据中 使用sqlite3_bind_blob接口

 
FILE* fp=fopen("user.bmp","rb");
iLen=fread(buffer,1,65535,fp);
fclose(fp);sqlite3_prepare(pDB,"insert into user values ('1001',?);",-1,&stmt,NULL);
sqlite3_bind_blob(stmt,1,buffer,iLen,NULL);
sqlite3_step(stmt);

二、使用blob接口函数,增量写入数据

 

int sqlite3_blob_open(sqlite3*,const char *zDb,const char *zTable,const char *zColumn,sqlite3_int64 iRow,int flags,sqlite3_blob **ppBlob
);


该接口打开位于数据库 zDb 中行 iRow、列 zColumn、表 zTable 中的 BLOB的句柄;换句话说,相同的 BLOB 将由以下人员选择:

SELECT zColumn FROM zDb.zTable WHERE rowid = iRow;
参数 zDb 不是包含数据库的文件名,而是数据库的符号名称。对于附加数据库,这是出现在ATTACH语句中 AS 关键字之后的名称。对于主数据库文件,数据库名称是“main”。对于 TEMP 表,数据库名称是“temp”。

将数据增量写入 BLOB

int sqlite3_blob_write(sqlite3_blob *, const void *z, int n, int iOffset);


该函数用于将数据从调用者提供的缓冲区写入打开的 BLOB handle 。N 个字节的数据从缓冲区 Z 复制到打开的 BLOB,从偏移量 iOffset 开始。

成功时,sqlite3_blob_write() 返回 SQLITE_OK。否则,将返回 error code 或 extended error code 。除非返回 SQLITE_MISUSE,否则此函数将设置可通过 sqlite3_errcode() 和 sqlite3_errmsg() 及相关函数访问的 database connection 错误代码和消息。

如果作为第一个参数传递的 BLOB handle 未打开进行写入( sqlite3_blob_open() 的 flags 参数为零),则此函数返回 SQLITE_READONLY 。

该函数只能修改BLOB的内容;使用此 API 无法增加 BLOB 的大小。如果偏移 iOffset 距离 BLOB 末尾小于 N 个字节,则返回 SQLITE_ERROR 并且不写入任何数据。BLOB 的大小(以及 N+iOffset 的最大值)可以使用 sqlite3_blob_bytes() 接口确定。如果 N 或 iOffset 小于零,则返回 SQLITE_ERROR 并且不写入任何数据。

尝试写入过期的 BLOB handle 失败,错误代码为 SQLITE_ABORT 。在 BLOB handle 过期之前发生的对 BLOB 的写入不会因句柄过期而回滚,尽管这些更改当然可能已被使 BLOB 句柄过期的语句或其他独立语句覆盖。

此例程仅适用于由先前成功调用 sqlite3_blob_open() 创建且尚未被 sqlite3_blob_close() 关闭的 BLOB handle 。将任何其他指针传递给此例程都会导致未定义的且可能是不良行为。

另请参阅: sqlite3_blob_read() 。

​在这里写个笔记,这几天要用到sqlite相关的函数 。

http://www.lryc.cn/news/427770.html

相关文章:

  • 在复杂的数据库架构中,如何优化 SQL 查询以提高性能和减少资源消耗?
  • 【HarmonyOS】端云一体化初始化项目
  • LLM之KG:利用大语言模型(LLM)对文本语料提取概念和概念之间的语义关系进而实现自动构建知识图谱
  • Spring Security 6如何使用?
  • PyTorch深度学习快速入门教程--学习笔记
  • SQLALchemy 分组过滤、子查询
  • 华为od(D卷) 环中最长子串/字符成环找偶数LOX
  • 机器学习--常见算法总结
  • QT 网络聊天室简易版
  • Linux_Shell三剑客grep,awk,sed-08
  • uniapp实现足球数据分析平台移动端H5
  • Redis5优化-Redis
  • Element UI【详解】el-scrollbar 滚动条组件
  • 【精选】基于Python大型购物商城系统(京东购物商城,淘宝购物商城,拼多多购物商城爬虫系统)
  • QT翻金币小游戏(含音频图片文件资源)
  • Linux配置JDK8环境变量
  • Fiddle抓手机app的包
  • Oracle+ASM+High冗余详解及空间计算
  • 如何为 Nextcloud 配置自动数据库备份 - 应用程序
  • child_process.spawn简介
  • 整理给测试人看的千页面试题
  • Linux 内核中的并发与竞争
  • Ubuntu修改命令提示符格式PS1
  • 指针详解(五)
  • 智慧安防/一网统管/视频监控EasyCVR视频汇聚平台的视频轻量化特点及应用
  • nginx代理转发如何配置
  • JavaScript学习笔记(十三):网络请求JS AJAX
  • go for 循环变量的使用及易错点
  • 2024嵌入式面试:OPPO嵌入式面试题及参考答案
  • Cesium模型制作,解决Cesium加载glb/GLTF显示太黑不在中心等问题