使用ADO执行存储过程 (转)

使用ADO执行存储过程 (转)[@more@]

ADO使你能够在客户程序中通过数据提供者来方便地处理数据.ADO主要的优点是容易使用、高速、低内存磁盘占用
在本文的示例工程中我们可以执行存储过程,传递参数给存储过程并接收它的返回值,以下是此过程的主要代码。

{ CString strTmp; CString m_sdatasource; // Data source name CString m_sUserID; // User Id CString m_sPassword; // Password // GET the above values from the user //Without creating Datasource we can use database by the following code /* strTmp.Format( "driver={sql SERVER};" "server=%s;" "Database=%s;""UID=%s;""PWD=%s;", m_server,m_sdatabase,m_sUserID,m_sPassword );*/ strTmp.Format( "dsn=%s;""UID=%s;""PWD=%s;",m_sdatasource,m_sUserID,m_sPassword ); _bstr_t bstrSQLServerConnect; _bstr_t bstrProc =( L"sp_StartByteImport" );; //Stored procedure name _variant_t Final; bstrSQLServerConnect = (LPCTSTR) strTmp; m_status="Empty File"; _ConnectionPtr Conn1; // connection object pointer _CommandPtr Cmd1; // command object pointer _RecordsetPtr Rs1; // recordset object pointer bool bvalid = false; try { Conn1.CreateInstance( __uuidof( Connection ) ); // Instantiating connection object Conn1->ConnectionString = bstrSQLServerConnect; // giving the sqlconnection Conn1->Open( bstrEmpty, bstrEmpty, bstrEmpty ); // open the connection object Cmd1.CreateInstance( __uuidof( Command ) ); // creating command object Cmd1->ActiveConnection = Conn1; // giving the connection handle Cmd1->CommandText = _bstr_t( bstrProc ); // passing the stored procedue Cmd1->CommandType = adCmdStoredProc; // type Cmd1->Parameters->Refresh(); // passing string value as argument to stored procedure Cmd1->Parameters->Item[ _variant_t( (long) 1 ) ]->Value = _variant_t( (LPCTSTR)m_sfilename ); Rs1 = Cmd1->Execute( &vtEmpty, &vtEmpty2, adCmdUnknown ); // executing the stored procedure and storing the recordset value bvalid = true; Final = Rs1->Fields->GetItem( _variant_t( 0L ) )->Value; // getting the first column value of the result row strTmp.Format( "%s", crackStrVariant( Final) ); // to see the value // put your code to see all column values } catch( CException *e ) // trapping all error messages { TCHAR szCause[255]; e->GetErrorMessage(szCause, 255); m_status=szCause; } catch( _com_error &e ) { m_status=e.ErrorMessage( ); } catch(...) { m_status="Error while executing the Import"; } //we need to create the stored procedures below before running the application //CREATE PROCEDURE sp_AddAccountingInfo @nfinal int, @pcDate datetime, //@pcURL varchar (250), @pcTop varchar (250), //@pcQueryString varchar (250), @pcBytes int, @pcRequests int AS /* Do your operation here */ //CREATE PROCEDURE sp_AddAccountingInfo //@nfinal int, //@pcDate datetime, //@pcURL varchar (250), //@pcTop varchar (250), //@pcQueryString varchar (250), //@pcBytes int, //@pcRequests int //AS /* Put your code here */ }

 
 

来自 “ ITPUB博客 ” ,链接:http://blog.itpub.net/10752043/viewspace-989903/,如需转载,请注明出处,否则将追究法律责任。

转载于:http://blog.itpub.net/10752043/viewspace-989903/

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值