关于VC中如何传递Recordset到ASP中的问题????

LuoQS1 2002-05-08 09:39:04
VC中如何传递Recordset到ASP,本人在线等候
...全文
22 3 打赏 收藏 转发到动态 举报
写回复
用AI写文章
3 条回复
切换为时间正序
请发表友善的回复…
发表回复
LuoQS1 2002-05-08
  • 打赏
  • 举报
回复
to masterz():
我试了一下发现在idl文件中的接口定义中
[id(5), helpstring("method GetADORecordset")] HRESULT GetADORecordset([out, retval] _Recordset **ppRecordset);
出现如下的编译错误如何解决
syntax error : expecting a type specification near "_Recordset"
LuoQS1 2002-05-08
  • 打赏
  • 举报
回复
先谢谢masterz() 我试试
masterz 2002-05-08
  • 打赏
  • 举报
回复
In your project make sure you import dll to create your ADO classes.



#import "c:\program files\common files\system\ado\msado15.dll" no_namespace rename("EOF", "adoEOF") implementation_only


Next create a method with an [out, retval] property of type _Recordset **


[id(1), helpstring("method GetADORecordset")] HRESULT GetADORecordset( [out, retval] _Recordset **ppRecordset);


Your source code should look something like this:


STDMETHODIMP CReturnADO::GetADORecordset(_Recordset **ppRecordset)
{

_ConnectionPtr pConnection;
_RecordsetPtr pRecordset;

try
{
pConnection.CreateInstance(__uuidof(Connection));
pConnection->CursorLocation = adUseClient; // Important for disconnected sets
pConnection->Open("DSN=SQLSource","loginnmae","password",-1);


pRecordset.CreateInstance(__uuidof(Recordset));
pRecordset->CursorLocation = adUseClient; // Important for disconnected sets

pRecordset->PutRefActiveConnection(pConnection.GetInterfacePtr()); // Associate the connection to this recordset

pRecordset->Open("SELECT DISTINCT name FROM TBLWHATEVER WHERE name IS NOT NULL",vtMissing,
adOpenForwardOnly, adLockReadOnly,
adCmdText);

pRecordset->PutRefActiveConnection(NULL); // Disassociate the connection from the recordset.

if(pConnection->GetState() == adStateOpen)
pConnection->Close();
pConnection = NULL;

*ppRecordset = pRecordset.Detach();

}
catch(_com_error *e)
{
return AtlReportError(CLSID_ReturnADO,e->ErrorMessage(),IID_IReturnADO,E_FAIL);
}
catch(...)
{
return AtlReportError(CLSID_ReturnADO,"Unknown Error.",IID_IReturnADO,E_FAIL);
}

return S_OK;
}
http://www.codeguru.com/mfc_database/disconnectedado.shtml

16,473

社区成员

发帖
与我相关
我的任务
社区描述
VC/MFC相关问题讨论
社区管理员
  • 基础类社区
  • Web++
  • encoderlee
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告

        VC/MFC社区版块或许是CSDN最“古老”的版块了,记忆之中,与CSDN的年龄几乎差不多。随着时间的推移,MFC技术渐渐的偏离了开发主流,若干年之后的今天,当我们面对着微软的这个经典之笔,内心充满着敬意,那些曾经的记忆,可以说代表着二十年前曾经的辉煌……
        向经典致敬,或许是老一代程序员内心里面难以释怀的感受。互联网大行其道的今天,我们期待着MFC技术能够恢复其曾经的辉煌,或许这个期待会永远成为一种“梦想”,或许一切皆有可能……
        我们希望这个版块可以很好的适配Web时代,期待更好的互联网技术能够使得MFC技术框架得以重现活力,……

试试用AI创作助手写篇文章吧