数据库的OLE字段写入长二进制文件
//'***************************************************************************************
//'函数:将数据库的OLE字段写入长二进制文件
//'***************************************************************************************
//bool THsPart_clsPartCommonDB::PrintFieldToFile(TheFiled As ADODB.Field, ByVal strSaveName As String, _
// Optional IsAppend As Boolean)
bool THsPart_clsPartEntityDB::PrintFieldToFile(_RecordsetPtr &myRcdPtr,_variant_t index ,CString strSaveName /*ADODB.Fields TheFiled, CString strSaveName ,*Optional IsAppend As Boolean*/)
{
//Dim MyRc As Recordset;
VARIANT varBLOB;
CFile myfile;
bool bReturn = false;
try
{
//'定义各种参数
const int conChunkSize = 16384;
int Chunks ;
byte *Chunk = NULL; //Chunk() As Byte,
//int FileNumber;
long FragMent ,lngTotalSize;
// 定义各种参数
myfile.Open(strSaveName,CFile::modeCreate|CFile::modeReadWrite|CFile::typeBinary);
/*FileNumber = FreeFile;
Open strSaveName For Binary Access Write As #FileNumber;*/
//将字段内的长二进制文件导出的文件
lngTotalSize = myRcdPtr->Fields->GetItem(index)->ActualSize; //lngTotalSize = TheFiled.ActualSize;
Chunks = lngTotalSize /conChunkSize;
FragMent = lngTotalSize % conChunkSize;
Chunk = (byte *)GlobalAlloc(GMEM_FIXED,FragMent); //ReDim Chunk(FragMent);
varBLOB= myRcdPtr->Fields->GetItem(index)->GetChunk(FragMent); //Chunk() = TheFiled.GetChunk(FragMent);
SafeArrayAccessData(varBLOB.parray,(void **)&Chunk);
LPSTR buffer = (LPSTR)GlobalLock((HGLOBAL)Chunk);
myfile.Write(buffer,FragMent);
GlobalUnlock((HGLOBAL)Chunk);
SafeArrayUnaccessData (varBLOB.parray);
int counter;
Chunk = (byte *)GlobalAlloc(GMEM_FIXED,conChunkSize);
for(counter=1;counter<= Chunks;counter++) //For counter = 1 To Chunks
{
//Chunk() = TheFiled.GetChunk(conChunkSize);
varBLOB= myRcdPtr->Fields->GetItem(index)->GetChunk(conChunkSize);
SafeArrayAccessData(varBLOB.parray,(void **)&Chunk);
buffer = (LPSTR)GlobalLock((HGLOBAL)Chunk);
myfile.Write(Chunk,FragMent);
SafeArrayUnaccessData (varBLOB.parray);
}
GlobalUnlock((HGLOBAL)Chunk);
Chunk = NULL;
buffer = NULL;
////////////////////////////////////////////////
////////////////////////////
//////////
//Close #FileNumber
myfile.Close();
bReturn = true;
return bReturn;
}
catch(...)
{
AfxMessageBox(_T("PrintFieldToFile wrong!"));
//Close #FileNumber;
myfile.Close();
}
return bReturn;
}
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· AI与.NET技术实操系列:基于图像分类模型对图像进行分类
· go语言实现终端里的倒计时
· 如何编写易于单元测试的代码
· 10年+ .NET Coder 心语,封装的思维:从隐藏、稳定开始理解其本质意义
· .NET Core 中如何实现缓存的预热?
· 分享一个免费、快速、无限量使用的满血 DeepSeek R1 模型,支持深度思考和联网搜索!
· 基于 Docker 搭建 FRP 内网穿透开源项目(很简单哒)
· ollama系列01:轻松3步本地部署deepseek,普通电脑可用
· 25岁的心里话
· 按钮权限的设计及实现