c++调用oracle存储过程,C++ ADO 调用存储过程方法

C++ ADO 调用存储过程方法

(最后更新日期 2011/09/22)

约定:

斜体字体表示可变部分

斜体

红色字体表示固定部分

红体

以下步骤的前提条件:COM ADO库已初始化,已经设置_ConnectionPtr连接对象。

步骤一: 创建 _CommandPtr 对象并初始化

_CommandPtr pCommand;

pCommand.CreateInstance(__uuidof(Command));

步骤二:设置_CommandPtr 对象的属性

1)设置连接字符串

pCommand->ActiveConnection = < _ConnectionPtr 类型的变量>;//连接字符串

例如:pCommand->ActiveConnection = m_OraDateBase.m_pConnection;

2) 标记该操作为存储过程 (如果存储过程输出参数为记录集,忽略此步骤)

pCommand->CommandType = adCmdStoredProc;

3)设置PLSQLRSet属性(如果存储过程输出参数不是记录集,忽略此步骤)

pCommand->Properties->GetItem("PLSQLRSet")->Value

= true;

步骤三:设置存储过程的输入/输出参数(如果没有输入参数忽略此步骤)

1) 创建 _ParameterPtr对象并初始化

_ParameterPtr pParam;

pParam.CreateInstance(__uuidof(Parameter));

2)设置_ParameterPtr对象的变量相关参数

pParam = pCommand->CreateParameter(,

,

,

);

: 这个名称会在取数据的时候用到

:变量类型可以参考以下网页:

http://school.it168.com/special/manual/ado/index.htm?url=/special/manual/ado/html/mdidxparametervcppsyntax.htm

:输入参数为:adParamInput 输出参数为:adParamOutput

:例如int为4 , 字符串为字符串的长度

例如:

pParam = pCommand->CreateParameter(_bstr_t("GAMEID"),

adInteger,

adParamInput,

4);

pParam = pCommand->CreateParameter(_bstr_t("val"),

adInteger,

adParamOutput,

4);

3)设置传入的变量值

(如果是输出参数忽略此步骤)

pParam->Value = _variant_t();

:

要设置的数值

4)加入到Command对象的参数集属性中

pCommand->Parameters->Append();

例如:

pCommand->Parameters->Append(pParam);

步骤四: 执行存储过程(返回记录集的情况)

1)

设置要调用的存储过程名称

pCommand->CommandText = _bstr_t((?));

:为数据库中存储过程的名称

?的个数为输入参数的个数,例如有三个输入参数,调用格式如下:

pCommand->CommandText = _bstr_t((?,?,?));

如下图:

a4c26d1e5885305701be709a3d33442f.png

3)

执行调用

=

pCommand->Execute(NULL,NULL,adCmdStoredProc |

adCmdUnspecified);

例如:

m_OraDateBase.m_pTempRecord = pCommand->Execute(NULL,NULL,adCmdStoredProc | adCmdUnspecified);

步骤四: 执行存储过程(一般情况)

1)

设置要调用的存储过程名称

pCommand->CommandText = _bstr_t();

:为数据库中存储过程的名称

如下图:

a4c26d1e5885305701be709a3d33442f.png

例如:

pCommand->CommandText = _bstr_t("RP_KEYWORDS_STATISTICS");

2)

执行调用

pCommand->Execute(NULL,NULL,adCmdStoredProc);

步骤五:获取输出参数结果

= pCommand->Parameters->GetItem()->GetValue();

:为C++中接收输出值的变量名

:为设置输出参数时设置的变量名称

完整调用示例:

存储过程代码:

create or replace

procedure RP_KEYWORDS_STATISTICS

(

v_keywords varchar2

)

IS

num number;

begin

select count(*) into num from

t_keywords where c_keycontent=v_keywords;

if num=0 then

insert into t_keywords select

sequence_keywords.nextval,v_keywords,1 from dual;

elsif num>0 then

update t_keywords set i_num=i_num+1 where

c_keycontent=v_keywords;

end if;

commit;

end

RP_KEYWORDS_STATISTICS;

C++ADO调用代码:

void CExecuteSql::LogUserSearchKey(std::string

strKey)

{

std::string strProcName;

_CommandPtr pCommand;

int iExpVal;

try {

pCommand.CreateInstance(__uuidof(Command));

pCommand->ActiveConnection = m_OraDateBase.m_pConnection;//连接字符串

pCommand->CommandType = adCmdStoredProc;//标记该操作为存储过程

_variant_t vt;

vt.SetString("2");

_ParameterPtr pParam, pParam1;

pParam.CreateInstance(__uuidof(Parameter));

pParam = pCommand->CreateParameter(_bstr_t("keyval"),adChar,adParamInput,strKey.length());//给参数设置各属性

pParam->Value = _variant_t( strKey.c_str() );

pCommand->Parameters->Append(pParam);//加入到Command对象的参数集属性中

pCommand->CommandText = _bstr_t("RP_KEYWORDS_STATISTICS");//存储过程名

pCommand->Execute(NULL,NULL,adCmdStoredProc);

//iExpVal =

pCommand->Parameters->GetItem("val")->GetValue();

} catch (_com_error e) {

CString m_strErrMsg;

m_strErrMsg.Format("LogUserSearchKey failure!\r\n\r\n

message error:%s\r\n\r\n", e.ErrorMessage());

printf("%s\n", m_strErrMsg.GetBuffer());

IsDatabaseClose();

iExpVal = 0;

//shGameCoin = 0;

return ;

}

return ;

}

【参考】

程序中调用的ADO函数的具体可用参数值可参考以下文档:

Microsoft ADO 程序员参考

C++中的Parameter类型和ADO的类型换转

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

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值