导航
  • 主页
  • VC综合技术
  • 互联网技术
  • MFC AppLauncher
  • .NET 技术
  • 界面
  • 进程
  • 算法
  • 硬件/系统
  • 数据库
  • VC++技术资源

如何在vc++利用odbc向sql sever 2000表中的image字段写入一个二进制数据

s_bj 2002-07-31 06:03:22
请教高手:
我使用的数据库是 sql server2000,现在有一张表的一个字段类型为Image,
应用程序的开发环境是vc++6.0,使用的数据库连接方式是odbc,请问如何向该表的iamge字段中插入一个二进制的数据!
...全文
48 点赞 收藏 4
写回复
4 条回复
切换为时间正序
请发表友善的回复…
发表回复
mfkzj 2002-08-01
你这里主要是建立ODBC数据连接
ODBC Driver for SQL Server
 
For Standard Security:

oConn.Open "Driver={SQL Server};" & _
          "Server=MyServerName;" & _
         "Database=myDatabaseName;" & _
         "Uid=myUsername;" & _
          "Pwd=myPassword;"

For Trusted Connection security:

oConn.Open "Driver={SQL Server};" & _
          "Server=MyServerName;" & _
          "Database=myDatabaseName;" & _
          "Uid=;" & _
          "Pwd=;"

' or

oConn.Open "Driver={SQL Server};" & _
          "Server=MyServerName;" & _
          "Database=myDatabaseName;" & _
          "Trusted_Connection=yes;"

To Prompt user for username and password

oConn.Properties("Prompt") = adPromptAlways
oConn.Open "Driver={SQL Server};" & _
          "Server=MyServerName;" & _
          "DataBase=myDatabaseName;"
  

For more information, see: SQLDriverConnect (ODBC)
写入数据:
char *pBuf = m_pBMPBuffer ;

VARIANT varBLOB;

SAFEARRAY *psa;

SAFEARRAYBOUND rgsabound[1];

m_pRecordset->AddNew(); ///添加新记录

m_pRecordset->PutCollect("username",_variant_t("小李")); ///为新记录填充username字段

m_pRecordset->PutCollect("old",_variant_t((long)28); ///填充old字段

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指向的二进制数据保存到SAFEARRAY对象psa中

varBLOB.vt = VT_ARRAY | VT_UI1;///将varBLOB的类型设置为BYTE类型的数组

varBLOB.parray = psa; ///为varBLOB变量赋值 m_pRecordset->GetFields()->GetItem("photo")->AppendChunk(varBLOB); ///加入BLOB类型的数据

}

m_pRecordset->Update(); ///保存我们的数据到库中

至此我们的数据已经成功地保存到了数据库中,接下来我们所要做的工作便是将该数据提取出来,让我们继续吧!

3.2 BLOB数据的读取

对应于保存数据时我们所使用的AppendChunk函数,读取数据应该使用GetChunk函数,GetChunk的原型如下:
_variant_t GetChunk (long Length );
给出数据的长度后GetChunk将返回包含数据的VARIANT类型变量,然后我们可以利用SafeArrayAccessData函数得到VARIANT变量中指向数据的char *类型的指针,以方便我们的处理,具体代码如下:

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);

  }

}

以上我们成功实现了BLOB数据在数据库中的存取,为了让大家有现成的例子可以参考,本文提供了示例工程,在示例工程中我们在数据库中保存图像数据,并可以对这些图像进行浏览、修改,该例子还涉及到如何用char *指向的BMP文件数据创建BITMAP对象然后显示出来。
回复
howtotell 2002-07-31
void CTeacherView::ReadImage()
{
try
{
if(m_pSet->IsEOF())
{ m_pSet->MoveLast();
return;
}
else{
HANDLE hFind;
WIN32_FIND_DATA FindData={0};
hFind=FindFirstFile("c:\\temp.bmp",&FindData);

if(hFind==INVALID_HANDLE_VALUE)
return;
else
{

DeleteFile("c:\\temp.bmp");
}

CString strFileName="c:\\temp.bmp";

CFile outFile(strFileName,CFile::modeCreate|CFile::modeWrite);

HBITMAP buffer=(HBITMAP)GlobalLock(m_pSet->m_TPhoto.m_hData);
outFile.WriteHuge(buffer,m_pSet->m_TPhoto.m_dwDataLength);
GlobalUnlock(m_pSet->m_TPhoto.m_hData);
outFile.Close();

LoadBMPFile("c:\\temp.bmp");
m_hPhotoBitmap = BufferToHBITMAP();
Invalidate();
}
}
catch(CException * pE)
{
pE->ReportError();
pE->Delete();
return; // TODO: Add your control notification handler code here
}
Invalidate();
UpdateData(FALSE);
}
回复
wanglei888 2002-07-31
CString strCmd = "update YourTable set Image1 = 0xfc024444666754543"

pDatabase->ExecuteSQL(strCmd);
回复
s_bj 2002-07-31
求救!
回复
发动态
发帖子
VC/MFC
创建于2007-09-28

1.5w+

社区成员

VC/MFC相关问题讨论
申请成为版主
社区公告

        VC/MFC社区版块或许是CSDN最“古老”的版块了,记忆之中,与CSDN的年龄几乎差不多。随着时间的推移,MFC技术渐渐的偏离了开发主流,若干年之后的今天,当我们面对着微软的这个经典之笔,内心充满着敬意,那些曾经的记忆,可以说代表着二十年前曾经的辉煌……
        向经典致敬,或许是老一代程序员内心里面难以释怀的感受。互联网大行其道的今天,我们期待着MFC技术能够恢复其曾经的辉煌,或许这个期待会永远成为一种“梦想”,或许一切皆有可能……
        我们希望这个版块可以很好的适配Web时代,期待更好的互联网技术能够使得MFC技术框架得以重现活力,……