惭愧啊!这么简单的数据库问题我都不会,你会吗?

zrq827 2003-08-07 02:44:58
您知道怎么用MFC的数据库类
CDatabase和CRecordset读写SQL中的image(blob)类型的数据吗?
在SQL中的Table中我有一个Field的数据类型是image(大二进制),
可是我在程序中怎样实现读写操作呢?
我也知道用ado或ODBC可以实现,可是我前期的许多工作都是用MFC的CDatabase和CRecordset实现的,又不能同时使用ado和MFC的CDatabase...

希望大伙帮个忙,不胜感激
...全文
25 15 打赏 收藏 转发到动态 举报
AI 作业
写回复
用AI写文章
15 条回复
切换为时间正序
请发表友善的回复…
发表回复
xiaozhuhululu 2003-08-07
  • 打赏
  • 举报
回复
谢谢了,我对oracle基本上没用过的,我看我得找本专门的书看看了

不过还是谢谢各位了,尤其是(vc++)兄台了
wbinsh 2003-08-07
  • 打赏
  • 举报
回复
sql 下show error
xiaozhuhululu 2003-08-07
  • 打赏
  • 举报
回复
我不会看啊,他都没有出来错误号,都快愁死了。是不是我在system用户下建的表的问题阿
wbinsh 2003-08-07
  • 打赏
  • 举报
回复
能看看oracle error是什么吗? 错误号是多少也可以.
xiaozhuhululu 2003-08-07
  • 打赏
  • 举报
回复
我试了,还是不好用捕获的错误是:source:Microsoft OLE DB Provider for ODBC sequence
Description:[Oracle][ODBC]Function Sequence error

这个错误是怎么回事啊,大家帮帮我啊
xiaozhuhululu 2003-08-07
  • 打赏
  • 举报
回复
还有会不会是我是在system用户名下system方案下建的表就不能加入这个blob字段啊,
按说,我其他字段都能存进去,这个字段不应该被限制吧,再不行,我就新建用户了
xiaozhuhululu 2003-08-07
  • 打赏
  • 举报
回复
我的程序除了pBuf定义的是BYTE*类型(即unsigned char*)外,别处没有差别啊,就是添加了blob字段后,update就会捕获错误,那我试试改成char*类型看看
mfkzj 2003-08-07
  • 打赏
  • 举报
回复
我怎么看着前面ADO的程序象是我写的????
呵呵
其实都是类似的 你需要先建立一个SAFEARRAY对象 具体的MSDN中有详细的解说
不明白的可以再问
wbinsh 2003-08-07
  • 打赏
  • 举报
回复
多谢了,xiaozhuhululu(小猪呼噜噜) ,你的这样写就可以了
zrq827 2003-08-07
  • 打赏
  • 举报
回复
return wbinsh(vc++) 用ADO

char *pBuf = m_pBMPBuffer;
VARIANT varBLOB;
SAFEARRAY *psa;
SAFEARRAYBOUND rgsabound[1];

m_pRecordset->AddNew(); ///添加新记录
if(pBuf)
{
rgsabound[0].lLbound = 0;
rgsabound[0].cElements = m_nFileLen;
psa = SafeArrayCreate(VT_UI1, 1, rgsabound); ///创建SAFEARRAY对象
for (long i = 0; i < (long)m_nFileLen; i++)
SafeArrayPutElement (psa, &i, pBuf++); /将pBuf指向的二进制数据保存到AFEARRAY对象                                      psa中
varBLOB.vt = VT_ARRAY | VT_UI1; ///将varBLOB的类型设置为BYTE类型的数组
varBLOB.parray = psa; ///为varBLOB变量赋值
m_pRecordset->GetFields()->GetItem("photo")->AppendChunk(varBLOB);
                     ///加入BLOB类型的数据
}
m_pRecordset->Update();


读:
long lDataSize = m_pRecordset->GetFields()->GetItem("photo")->ActualSize;///得到数据的长度
if(lDataSize > 0)
{
_variant_t varBLOB;
varBLOB = m_pRecordset->GetFields()->GetItem("photo")->GetChunk(lDataSize);
if(varBLOB.vt == (VT_ARRAY | VT_UI1)) ///判断数据类型是否正确
{
char *pBuf = NULL;
SafeArrayAccessData(varBLOB.parray,(void **)&pBuf); ///得到指向数据的指针
/*****在这里我们可以对pBuf中的数据进行处理*****/
SafeArrayUnaccessData (varBLOB.parray);
}
}
丁淇石头 2003-08-07
  • 打赏
  • 举报
回复
这段程序就是将*.bmp文件存入Image中, 有的地方我也不太明白
CString Sql;
CFile fileImage;
CFileStatus fileStatus;

if (m_strFileName==_T(""))
return;

Sql.Format("select * from TableName where ID = 5");

CYouRecordSetSet * pYouRecordSetSet = new CYouRecordSetSet;

try
{
pYouRecordSetSet->Open(AFX_DB_USE_DEFAULT_TYPE,Sql,0);
}
catch(CException* pE)
{
pE->ReportError();
pE->Delete();
return;
}
if (pYouRecordSetSet->GetRecordCount()<=0)
pYouRecordSetSet->AddNew();
else
pYouRecordSetSet->Edit();

fileImage.Open(m_strFileName, CFile::modeRead);
fileImage.GetStatus(fileStatus);

pYouRecordSetSet->m_Image.m_dwDataLength = fileStatus.m_size;

HGLOBAL hGlobal = GlobalAlloc(GPTR, fileStatus.m_size);
pYouRecordSetSet->m_Image.m_hData = GlobalLock(hGlobal);

fileImage.ReadHuge(pYouRecordSetSet->m_Image.m_hData, fileStatus.m_size);

pYouRecordSetSet->SetFieldDirty(&pYouRecordSetSet->m_Image);

pYouRecordSetSet->SetFieldNull(&pYouRecordSetSet->m_Image, FALSE);

pYouRecordSetSet->Update();

GlobalUnlock(hGlobal);

pYouRecordSetSet->Close();
delete pYouRecordSetSet;
wbinsh 2003-08-07
  • 打赏
  • 举报
回复
你是用ADO的啊,他是用ODBC的.
xiaozhuhululu 2003-08-07
  • 打赏
  • 举报
回复
我也在为blob发愁呢,我是要把blob类型写到oracle中,那段程序写到access的image类型中就好用,我的就不好用

555555
wbinsh 2003-08-07
  • 打赏
  • 举报
回复
能问一下你ADO怎么实现吗?
康斯坦汀 2003-08-07
  • 打赏
  • 举报
回复
記得msdn有相關的文章,帶例子源碼。自己找一下。

CByteArray類和CLongBinary類

4,018

社区成员

发帖
与我相关
我的任务
社区描述
VC/MFC 数据库
社区管理员
  • 数据库
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
暂无公告

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