ADO操作数据的几个问题
2004-11-20 00:09
549 查看
总结了几个在用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) ;
}
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) ;
}
相关文章推荐
- 网易收费330M邮箱免费获得 天下真的有免费的午餐
- 如何获得十亿分之一秒的时钟精度
- 我的hotmail信箱容量变成2G了!
- Google中文版推出搜索结果翻译功能BETA版
- GARFIELD@11-19-2004
- 职业生涯规划培训
- 你知道‘PHP探针’吗?
- 将PHP作为Shell脚本语言使用
- HWS与Workflow Solution Framework的区别
- Building Windows Forms Controls and Components with Rich Design-Time Features
- Wallop太可怕了!
- 马尔代夫还是欧洲四国,这不是问题。
- ASP生成静态htm页面基本代码!
- VB水晶报表每讲学生反馈总结(总结人:陈佳云)
- 打排球
- java连接sqlserver实例
- log4j多文件输入日志
- 软件R的安装和使用(视窗电脑)
- 正在学的FLASH:原灵动嘻哈势力网站制作教程
- Eclipse 3.0 RC2 熱鍵表