zoukankan      html  css  js  c++  java
  • ADO操作数据的几个问题

    总结了几个在用ADO操作数据库的时候常遇见的问题。
    1
    读数据库中的二进制数据,在论坛里有人提到用GetChunk不行,只能读Image类型的数据,下面是一个声音数据的例子:
    long lDataSize = m_adoRecordSet.GetFields()->GetItem("声音")->ActualSize;
    if(lDataSize > 0)
    {
       _variant_t varBLOB;
       varBLOB = m_adoRecordSet.GetFields()->GetItem("声音")->GetChunk(lDataSize);
       if(varBLOB.vt == (VT_ARRAY | VT_UI1))
       {
        char *pBuf = NULL;
        SafeArrayAccessData(varBLOB.parray,(void **)&pBuf);
        sndPlaySound(pBuf, SND_MEMORY | SND_SYNC | SND_NODEFAULT );//播放声音
        SafeArrayUnaccessData(varBLOB.parray);//注意这句不能少的
      }
    }

    2
    在DLL中引入ADO库
    采用下面方法在stdafx中加入
    #import "C:/Program Files/Common Files/System/ADO/msado15.dll" no_namespace rename("EOF","adoEOF")
    引入ADO库的时候可能会遇到下面一些错误信息,说是有EditModeEnum、RecordStatusEnum、ParameterDirectionEnum、LockTypeEnum、DataTypeEnum、FieldAttributeEnum重定义!总是编译通不过。
    遇到这种情况可以试试改成
    #pragma warning(disable:4146)
    #import "C:/Program Files/Common Files/System/ADO/msado15.dll" named_guids rename("EOF","adoEOF"), rename("BOF","adoBOF")
    #pragma warning(default:4146)
    using namespace ADODB;

    3
    读写时间值的操作,下面只是一种可行的方法,可能还存在其他更好的方法。
    写入时间值
    COleDateTime oleDate = COleDateTime::GetCurrentTime();
    _variant_t vtFld;
    vtFld.vt = VT_DATE;
    vtFld.date = oleDate;
    pRecordSet->PutCollect("出生年月", vtFld);

    读时间值
    _bstr_t TheValue=m_pset->Fields->GetItem("出生年月")->Value;
    temp=(char *)TheValue;
    COleVariant vtime(temp);
    vtime.ChangeType(VT_DATE);
    COleDateTime time=vtime;

    4
    压缩ACCESS数据库

    Reference:  MS KB Article ID:Q230501  Compacting an Access Database via ADO
    #import "C:/PROGRAM FILES/COMMON FILES/System/ado/MSJRO.DLL" no_namespace
    try
    {
        IJetEnginePtr jet(__uuidof(JetEngine));
        jet->CompactDatabase( "Provider=Microsoft.Jet.OLEDB.4.0;Data Source=d://nwind2.mdb;Jet OLEDB:Database Password=test",
      "Provider=Microsoft.Jet.OLEDB.4.0;Data Source=d://abbc.mdb;" /
      "Jet OLEDB:Engine Type=4;Jet OLEDB:Database Password=test");
    }
    catch(_com_error &e)
    {      
       ::MessageBox(NULL, (LPCTSTR)e.Description( ), "", MB_OK) ;   
    }

  • 相关阅读:
    javascript 获取鼠标在盒子中的坐标
    jquery中clientY, pageY, screenY的区别,最后三张图一目了然
    javascript 小清新颜色翻页效果
    javascript 缓动返回顶部案例
    原生js轮播图实现
    javascript Math对象
    javascript 获取节点元素的封装
    javascript 转换大小写字母
    2017 ACM-ICPC 亚洲区(青岛赛区)网络赛 1010
    2017 ACM-ICPC 亚洲区(青岛赛区)网络赛 1009
  • 原文地址:https://www.cnblogs.com/hehe520/p/6330145.html
Copyright © 2011-2022 走看看