操作数据的几个问题计划

2021-08-24 淮安装修公司

总结了几个在用ADO操作数据库的时候常遇见的问题。

1

读数据库中的二进制数据,在论坛里有人提到用GetChunk不行,只能读Image类型的数据,下面是一个声音数据的例子:

long lDataSize = m_tFields()-GetItem(\"声音\")-ActualSize;

if(lDataSize 0)

{

_variant_t varBLOB;

varBLOB = m_tFields()-GetItem(\"声音\")-GetChunk(lDataSize);

if( == (VT_ARRAY | VT_UI1))

{

char *pBuf = NULL;

SafeArrayAccessData(rray,(void **)pBuf);

sndPlaySound(pBuf, SND_MEMORY | SND_SYNC | SND_NODEFAULT );//播放声音

SafeArrayUnaccessData(rray);//注意这句不能少的

}

}

2

在DLL中引入ADO库

采用下面方法在stdafx中加入

#import \"C:Program FilesCommon l\" no_namespace rename(\"EOF\",\"adoEOF\")

引入ADO库的时候可能会遇到下面一些错误信息,说是有EditModeEnum、RecordStatusEnum、ParameterDirectionEnum、LockTypeEnum、DataTypeEnum、FieldAttributeEnum重定义!总是编译通不过。

遇到这种情况可以试试改成

#pragma warning(disable:4146)

#import \"C:Program FilesCommon l\" named_guids rename(\"EOF\",\"adoEOF\"), rename(\"BOF\",\"adoBOF\")

#pragma warning(default:4146)

using namespace ADODB;

3

读写时间值的操作,下面只是一种可行的方法,可能还存在其他更好的方法。

写入时间值

COleDateTime oleDate = COleDateTime::GetCurrentTime();

_variant_t vtFld;

= VT_DATE;

te = oleDate;

我们这个团的20多名游客几乎都采购了各式各样的玉器。等我们上车后 pRecordSet-PutCollect(\"出生年月\", vtFld);

读时间值

_bstr_t TheValue=m_pset-Fields-GetItem(\"出生年月\")-Value;

temp=(char *)TheValue;

COleVariant vtime(temp);

angeType(VT_DATE);

COleDateTime time=vtime;

4

压缩ACCESS数据库,

Reference: MS KB Article ID:Q230501 Compacting an Access Database via ADO

#import \"C:PROGRAM FILESCOMMON L\" no_namespace

try

{

IJetEnginePtr jet(__uuidof(JetEngine));

jet-CompactDatabase( \"Provider=EDB.4.0;Data Source=d:b;Jet OLEDB:Database Password=test\",

\"Provider=EDB.4.0;Data Source=d:b;\"

\"Jet OLEDB:Engine Type=4;Jet OLEDB:Database Password=test\");

}

catch(_com_error e)

{

::MessageBox(NULL, (LPCTSTR)scription( ), \"\", MB_OK) ;

}

天水治疗白癜风的医院
冠心病合并高血压吃什么药
杭州治白癜风医院哪好
为你推荐