SQLite数据库中存取图片文件

简介:

前段时间在做一款嵌入式项目,用到了SQLite数据库,现在就SQLite数据库中存取图片问题来与大家共享一下,

对于二进制数据我们自然是不能够直接进行存储,在SQLite中我们可以将其转换而后存储。
下面就言归正传
在对主句操作之前我们先要打开数据库,SQLite给用户提供了丰富的API,足以使我们来驾驭它,
利用sqlite3_open()函数,打开我们所要操作的数据库,
接下来就是对于我们的图片文件的操作了,我在这里的方法便是将图片文件转换成字符流,而后进行存储。
下面我就以一个简单的范例来说明问题吧.....

#include <stdio.h>
#include <sqlite3.h>
#include <stdlib.h>
static sqlite3 *db=NULL;
static sqlite3_stmt *stmt=NULL;
FILE *fp;
long filesize=0;
char *fflie;

int main(int argc, char *argv[])
{
        int rc,i,j;
        rc =  sqlite3_open("dishes.db", &db);
        rc =  sqlite3_prepare(db, "update dishes_table set dish_image=?where dish_name='x';", -1, &stmt, 0);
       fp=fopen("x.jpg","rb");
       if(fp != NULL)
      {
            fseek(fp, 0, SEEK_END);
            filesize = ftell(fp);
            fseek(fp, 0, SEEK_SET);
  
            ffile = (char *)malloc(filesize + 1);
            size_t sz = fread(ffile, sizeof(char), filesize+1, fp);
            fclose(fp);
     }
     sqlite3_bind_blob(stmt, 1, ffile, filesize, NULL);
     rc=sqlite3_step(stmt);
     free(ffile);
     sqlite3_finalize(stmt);
     sqlite3_close(db);
     return 0; 
 
}



     本文转自 驿落黄昏 51CTO博客,原文链接:http://blog.51cto.com/yiluohuanghun/835509,如需转载请自行联系原作者



相关文章
|
16天前
|
监控 关系型数据库 数据库
OceanBase数据库常见问题之文件存在但是数据库提示文件不存在如何解决
OceanBase 是一款由阿里巴巴集团研发的企业级分布式关系型数据库,它具有高可用、高性能、可水平扩展等特点。以下是OceanBase 数据库使用过程中可能遇到的一些常见问题及其解答的汇总,以帮助用户更好地理解和使用这款数据库产品。
|
17天前
|
API 数据库 C语言
【C/C++ 数据库 sqlite3】SQLite C语言API返回值深入解析
【C/C++ 数据库 sqlite3】SQLite C语言API返回值深入解析
160 0
|
29天前
|
存储 关系型数据库 MySQL
如何处理爬取到的数据,例如存储到数据库或文件中?
【2月更文挑战第23天】【2月更文挑战第73篇】如何处理爬取到的数据,例如存储到数据库或文件中?
|
22天前
|
SQL Java 数据库连接
从来没想到我们会扒拉nohup文件去找我们想要的数据,然后往数据库中添加。。。...
从来没想到我们会扒拉nohup文件去找我们想要的数据,然后往数据库中添加。。。...
17 0
|
2月前
|
存储 监控 安全
内网屏幕监控软件的数据存储与管理:使用SQLite数据库保存监控记录和配置信息
在当今数字化时代,安全和监控在企业和组织中变得至关重要。内网屏幕监控软件作为一种关键工具,帮助组织监视员工的活动并确保信息安全。这种软件不仅需要高效地记录和管理监控数据,还需要能够方便地进行配置和调整。本文将讨论如何使用SQLite数据库来保存监控记录和配置信息,并介绍如何通过自动化机制将监控到的数据提交到指定网站。
138 2
|
22天前
|
SQL Java 数据库连接
springboot解析txt文件顺便加到数据库中(nohup文件)
springboot解析txt文件顺便加到数据库中(nohup文件)
108 1
|
28天前
|
关系型数据库 数据库 C++
嵌入式数据库sqlite3【基础篇】基本命令操作,小白一看就懂(C/C++)
嵌入式数据库sqlite3【基础篇】基本命令操作,小白一看就懂(C/C++)
|
30天前
|
存储 SQL 数据库
django如何连接sqlite数据库?
django如何连接sqlite数据库?
33 0
|
1月前
|
存储 PHP Apache
使用CFimagehost源码搭建无需数据库支持的PHP免费图片托管私人图床
使用CFimagehost源码搭建无需数据库支持的PHP免费图片托管私人图床
|
2月前
|
SQL 数据库管理
sqlite语句order by两个字段同时排序处理
sqlite语句order by两个字段同时排序处理
19 0