如何向数据库中插入二进制文件?我用的是c++/connector

Love_TuRong 2009-07-03 10:11:35
我用的是c++/connector
有很多图片文件想导入到数据库里
数据库的格式是 id interger filename varchar(45) file
blob
我想知道如果用程序导入的话
语句该怎么写?
直接写("insert into map0(1,\"0.png\",\"0.png\")")貌似不对
我想使用PreparedStatement 但是提示:
错误 1 error C2027: 使用了未定义类型“sql::PreparedStatement” d:\Project\mysqltest\mysqltest\mysqltest.cpp 49
下面是我的部分代码

// mysqltest.cpp : 定义控制台应用程序的入口点。
//

#include "stdafx.h"

#include <stdlib.h>
#include <iostream>
#include <sstream>
#include <fstream>

/// 注:最好不要直接操作mysql,而通过接口来操作
/// mysql这么做的意义何在?难道还有多种实现?


//#include <mysql_connection.h>
//#include <mysql_driver.h>

#include <cppconn/connection.h>
#include <cppconn/driver.h>
#include <cppconn/exception.h>
#include <cppconn/resultset.h>
#include <cppconn/statement.h>


using namespace std;
using namespace sql;

int main(int argc, char *argv[])
{

Driver *driver;
Connection *con;
//prep_stmt;
ResultSet *res;


// string query="insert into map0(1,?,?)";


///// 创建数据库连接驱动
driver = get_driver_instance();

/// 连接远程数据库
con = driver->connect("tcp://localhost:3306", "root", "m172"); // OK
/// 设置连接的数据库
con->setSchema("mapic");
/// 创建执行器
PreparedStatement *prep_stmt= con->prepareStatement("insert into map0(1,?,?)");
prep_stmt->SetString(1,"0.png");


/// 输出记录集到控制台

ifstream ifs("0.png");
ifs.seekg(0,ios::end); //设置文件指针到文件流的尾部
streampos ps = ifs.tellg();

//释放掉句柄
delete res;
delete prep_stmt;
delete con;

return 0;
}

...全文
128 4 打赏 收藏 转发到动态 举报
写回复
用AI写文章
4 条回复
切换为时间正序
请发表友善的回复…
发表回复
lcyw 2010-12-21
  • 打赏
  • 举报
回复
楼主搞定了吗? 把解决方法分享一下啊
Love_TuRong 2009-07-16
  • 打赏
  • 举报
回复
呵呵 还是谢谢你啦
ZhangHuaTong 2009-07-06
  • 打赏
  • 举报
回复
char *buff,*data,*escfilename
为 buff,data,escfilename 分配内存,buff的大小为文件的大小,data的大小为buff的大小的2位加1,escfilename的大小为文件名的大小的2倍加1

打开文件,将文件读入 buff
然后再:
mysql_real_escape_string(sql,escfilename,filename,strlen(filename))
mysql_real_escape_string(sql,data,buff,filesize)

SQL语句这样试一下
sprintf(SQL,"insert into map0(id,filename,file) values(1,'%s','%s')",filename,data)
mysql_query(sql,SQL)
Love_TuRong 2009-07-03
  • 打赏
  • 举报
回复
我用的是c++/connector
有很多图片文件想导入到数据库里
格式是 id interger filename varchar(45) file blob
我想知道如果用程序导入的话
那个语句该怎么写?
直接写("insert into map0(1,\"0.png\",\"0.png\")")貌似不对

56,675

社区成员

发帖
与我相关
我的任务
社区描述
MySQL相关内容讨论专区
社区管理员
  • MySQL
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
暂无公告

试试用AI创作助手写篇文章吧