操作数据的几个问题覆盖
2021-08-24 12:57:36 菏泽汽车网
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 Files\\Common Files\\System\\ADO\\l\" no_namespace rename(\"EOF\",\"adoEOF\")
引入ADO库的时候可能会遇到下面一些错误信息,说是有EditModeEnum、RecordStatusEnum、ParameterDirectionEnum、LockTypeEnum、DataTypeEnum、FieldAttributeEnum重定义!总是编译通不过。
遇到这种情况可以试试改成
#pragma warning(disable:4146)
#import \"C:\\Program Files\\Common Files\\System\\ADO\\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;
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 FILES\\COMMON FILES\\System\\ado\\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) ;
}
查看本文来源
小孩不爱吃饭怎么办黄芪生脉饮适合什么人群
南昌睾丸炎治疗费用
- 上一篇:操作数据的几个问题计划
- 下一篇:编程中所遇到的定义问题牛