SQlite存取图像数据总结

需要源码的评论区留言

1、首先利用openCV读取图像

cv::Mat img = cv::imread("/home/hjj/demo.jpg",1);

2、在SQlite创建的表中增加一个BLOB类型的字段,用于存储图像数据。如字段id INTEGER, image BLOB

std::string sql = std::string("CREATE TABLE IF NOT EXISTS demo_table(id INTEGER PRIMARY KEY, image BLOB)");
sqlite3* db_;
char* errmsg;
int result = sqlite3_exec(db_,sql.c_str(),NULL,NULL,&errmsg);
if(result != SQLITE_OK){
  std::cout << "Create Table Failed:" << errmsg << std::endl;
}else {
  std::cout << "Create Table Succeed" << std::endl;
}


3、将图像数据转换为std::string 类型

std::string image_data(img.begin<unsigned char>(),img.end<unsigned char>());

4、将std::string类型的图像数据插入到BLOB字段

sqlite3_stmt* pStml = NULL;
char* errmsg;
std::string sql("INSERT INTO demo_table VALUES(1,?)");
sqlite3_prepare(db_,sql.c_str(),strlen(sql.c_str()),&pStml,0);
sqlite3_bind_blob(pStml,1,img_data.c_str(),img.cols*img.rows,NULL);
sqlite3_step(pStml);

5、从SQlite数据库中读取图像数据

unsigned char* charBuf = (unsigned char*)sqlite3_column_blob(stmt,0);//0表示查询表中的第一个数据
std::vector<unsigned char> vectordata(charBuf,charBuf+img.cols*img.rows);
cv::Mat picture(img.rows,img.cols,CV_8UC1,vectordata.data());
cv::imshow("test window",picture);
cv::waitKey(0);
搞定!!!

  • 2
    点赞
  • 8
    收藏
    觉得还不错? 一键收藏
  • 7
    评论
评论 7
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值