ado调用存储过程(带输出参数)


    CoInitialize(NULL);

    _ConnectionPtr pMyConnect=NULL;
    HRESULT hr=pMyConnect.CreateInstance(__uuidof(Connection));
    if(FAILED(hr))return;

    _bstr_t strConnect="Provider=SQLOLEDB; Server=7BWZ82X-XP-CN//sqlexpress;"
        "Database=wx; uid=sa; pwd=123456;";
    //connecting to the database server now:
    try{pMyConnect->Open(strConnect,"","",NULL);}
    catch (_com_error &e)
    {
        ::MessageBox(NULL,e.Description(),_T("警告"),MB_OK|MB_ICONWARNING);
    }


    _CommandPtr     pCmd = NULL;

    _RecordsetPtr   pRecordset = NULL;

    pCmd.CreateInstance(__uuidof(Command));

    pRecordset.CreateInstance(_uuidof(Recordset));

    pCmd->ActiveConnection = pMyConnect;

    pCmd->CommandType = adCmdStoredProc;

    pCmd->CommandText=_bstr_t(_T("Login"));  //SP Name
    pCmd->Parameters->Refresh(); 

    char chId[65];
    sprintf(chId,"%ld", time(0));

    pCmd->Parameters->GetItem((long)1)->Value = _variant_t(4); 
    pCmd->Parameters->GetItem((long)2)->Value = _variant_t("44"); 

    /*pRecordset =  */pCmd->Execute(NULL,NULL,adCmdStoredProc);

    //pRecordset.Release();
    _variant_t v= pCmd->Parameters->GetItem((long)0)->Value;
    CString str;
    str.Format(_T("%d"), v.intVal);
    MessageBox(str);
     v= pCmd->Parameters->GetItem((long)3)->Value;
     str;
    str.Format(_T("%d"), v.intVal);
    MessageBox(str);

    pCmd.Release();
    pMyConnect.Release();

    CoUninitialize();

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值