void Caccess_test_1Dlg::OnBnClickedButton3()//将偏振图像存入数据库
{
// TODO: 在此添加控件通知处理程序代码
if (!PathFileExists(_T(filename)))
{
AfxMessageBox(_T("数据库不存在!\r请创建数据库!"));
return;
}
try
{
m_pConnection.CreateInstance(__uuidof(Connection));
m_pRecordset.CreateInstance("ADODB.Recordset");
m_pConnection->Open(StrCmd, "", "", adModeUnknown);
m_pRecordset->Open("SELECT * FROM p ", _variant_t(m_pConnection, true), adOpenStatic, adLockOptimistic, adCmdText);
}
catch (_com_error e)
{
CString errormessage;
errormessage.Format(_T("连接数据库失败!\r错误信息:%s"), e.ErrorMessage());
AfxMessageBox(errormessage);
return;
} CFile f;
CString FilePathName;
CFileException e; CFileDialog dlg(TRUE,NULL, NULL, , L"jpg Files (*.jpg)|*.jpg||", this);///TRUE为OPEN对话框,FALSE为SAVE AS对话框
if (dlg.DoModal() == IDOK)
{
FilePathName = dlg.GetPathName(); if (m_Pic.m_IPicture != NULL) m_Pic.FreePictureData(); // Important - Avoid Leaks... if (f.Open(FilePathName, CFile::modeRead | CFile::typeBinary, &e)) //打开了一个jpg文件
{ int nSize = f.GetLength(); //先得到jpg文件长度
BYTE * pBuffer = new BYTE[nSize]; //按文件的大小在堆上申请一块内存 if (f.Read(pBuffer, nSize) > ) //把jpg文件读到pBuffer(堆上申请一块内存)
{ // +----------------------------------------------
BYTE *pBuf = pBuffer; ///下面这一大段是把pBuffer里的jpg数据放到库中
VARIANT varBLOB;
SAFEARRAY *psa;
SAFEARRAYBOUND rgsabound[];
//m_pRecordset.CreateInstance(__uuidof(Recordset)); m_pRecordset->AddNew();
if (pBuf)
{
rgsabound[].lLbound = ;
rgsabound[].cElements = nSize;
psa = SafeArrayCreate(VT_UI1, , rgsabound);
for (long i = ; i < (long)nSize; i++)
SafeArrayPutElement(psa, &i, pBuf++);
varBLOB.vt = VT_ARRAY | VT_UI1;
varBLOB.parray = psa;
m_pRecordset->GetFields()->GetItem("偏振度图像")->AppendChunk(varBLOB);
}
m_pRecordset->Update();
// +----------------------------------------------
//(m_Pic.LoadPictureData(pBuffer, nSize));//接作调用函数读pBuffer的jpg数据准备显示
delete[] pBuffer; //删掉堆上申请的那一块内存
pBuf = ; //以防二次乱用
}
f.Close();
} // CClientDC dc(this);
//m_Pic.UpdateSizeOnDC(&dc); // Get Picture Dimentions In Pixels
//m_Pic.Show(&dc, CRect(0, 50, m_Pic.m_Width, 50 + m_Pic.m_Height)); //显示出来看看 }
//Invalidate();
}

m_pRecordset.CreateInstance

最新文章

  1. jQuery css3仿游戏网站右键环形菜单
  2. OAuth2.0说明文档
  3. java面向对象(封装-继承-多态)
  4. Mysql数据库优化
  5. Android Studio 经常使用功能介绍
  6. HTML中多媒体的应用_Flash/MP3/设置可以活动的文字
  7. LFS7.4编译笔记(3)
  8. Linux FTP服务安装和远程登录失败
  9. [工具]前端自动化工具grunt+bower+yoman
  10. 基于Daydream technical preview GVR13开发Daydream,Cardboard的Android应用
  11. ZED-Board从入门到精通系列(八)——Vivado HLS实现FIR滤波器
  12. PHP编码规范及建议
  13. web SPA项目目录、命名规范
  14. [面试] Java GC (未整理完)
  15. mysql触发器trigger 实例详解
  16. 1 C++ 线程
  17. IDEA激活
  18. python之路——1
  19. ubuntu卸载福昕阅读器
  20. SV中的Interface和Program

热门文章

  1. Oracle 12C 在 Oracle Linux 6.5 64Bit 安装手冊
  2. Error LNK2019:Unresolved External Symbol 的解决方案
  3. hdoj1171 Big Event in HDU
  4. Ubuntu下安装JDK1.7
  5. mysql 5.7.15 安装配置方法图文教程(转)
  6. 引用第三方高德地图接口---使用js脚本进行开发地图定位的步骤
  7. eclipse egit 解决冲突
  8. eclipse memory内存溢出
  9. js JSON对象与字符串相互转换
  10. maven jetty指定端口启动