热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

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

约定:斜体字体表示可变部分斜体红色字体表示固定部分红体以下步骤的前提条件:COMADO库已初始化,已经设置_ConnectionPtr连接

约定:

斜体字体表示可变部分   斜体

红色字体表示固定部分   红体

 

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

 

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

 

     _CommandPtr pCommand;

pCommand.CreateInstance(__uuidof(Command));

 

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

 

1)设置连接字符串

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

例如&#xff1a;pCommand->ActiveConnection &#61; m_OraDateBase.m_pConnection;

 

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

pCommand->CommandType &#61; adCmdStoredProc;

 

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

pCommand->Properties->GetItem("PLSQLRSet")->Value &#61; true;

步骤三&#xff1a;设置存储过程的输入/输出参数&#xff08;如果没有输入参数忽略此步骤&#xff09;

 

   1) 创建 _ParameterPtr对象并初始化

        _ParameterPtr pParam;

        pParam.CreateInstance(__uuidof(Parameter));

 

   2&#xff09;设置_ParameterPtr对象的变量相关参数

     pParam &#61; pCommand->CreateParameter(<变量名称>,

<变量类型>,

<创建类型>,

<变量大小>);

   <变量名称> : 这个名称会在取数据的时候用到

   <变量类型> &#xff1a;变量类型可以参考以下网页&#xff1a;

  http://school.it168.com/special/manual/ado/index.htm?url&#61;/special/manual/ado/html/mdidxparametervcppsyntax.htm

 

<创建类型>&#xff1a;输入参数为&#xff1a;adParamInput 输出参数为&#xff1a;adParamOutput

<变量大小> &#xff1a;例如int4 &#xff0c; 字符串为字符串的长度

 

  例如&#xff1a;

 pParam &#61; pCommand->CreateParameter(_bstr_t("GAMEID"),

adInteger,

adParamInput,

4);

pParam &#61; pCommand->CreateParameter(_bstr_t("val"),

adInteger,

adParamOutput,

4);

 

   3&#xff09;设置传入的变量值 (如果是输出参数忽略此步骤)

    pParam->Value &#61; _variant_t(变量值>);

变量值> : 要设置的数值

 

4&#xff09;加入到Command对象的参数集属性中

pCommand->Parameters->Append(参数对象名>);

例如&#xff1a;

pCommand->Parameters->Append(pParam);

 

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

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

pCommand->CommandText &#61; _bstr_t(<存储过程名称>&#xff08;?&#xff09;);

<存储过程名称>&#xff1a;为数据库中存储过程的名称

?的个数为输入参数的个数&#xff0c;例如有三个输入参数&#xff0c;调用格式如下&#xff1a;

pCommand->CommandText &#61; _bstr_t(<存储过程名称>&#xff08;?,?,?&#xff09;);

 

   如下图&#xff1a;

  

 

3)      执行调用

<记录集对象指针> &#61;

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

例如&#xff1a;

m_OraDateBase.m_pTempRecord &#61; pCommand->Execute(NULL,NULL,adCmdStoredProc | adCmdUnspecified);

 

 

 

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

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

     pCommand->CommandText &#61; _bstr_t(<存储过程名称>);

<存储过程名称>&#xff1a;为数据库中存储过程的名称

 

   如下图&#xff1a;

  



例如&#xff1a;

pCommand->CommandText &#61; _bstr_t("RP_KEYWORDS_STATISTICS");

 

2)      执行调用

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

 

步骤五&#xff1a;获取输出参数结果

 

<变量名> &#61; pCommand->Parameters->GetItem(<输出参数名>)->GetValue();

 

<变量名> &#xff1a;C&#43;&#43;中接收输出值的变量名

<输出参数名> &#xff1a;为设置输出参数时设置的变量名称

 

 

 

完整调用示例&#xff1a;

存储过程代码&#xff1a;

create or replace procedure RP_KEYWORDS_STATISTICS

(
    v_keywords varchar2
 )
   IS
     num number;

     begin
     select count(*) into num from t_keywords where c_keycontent&#61;v_keywords;
     if num&#61;
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&#61;i_num&#43;
1 where c_keycontent&#61;v_keywords;
     end if;
    
     commit;

 end RP_KEYWORDS_STATISTICS;

C&#43;&#43;ADO调用代码&#xff1a;

 

void CExecuteSql::LogUserSearchKey(std::string strKey)

{

    std::string strProcName;

    _CommandPtr pCommand;

    int iExpVal;

 

    try {

 

        pCommand.CreateInstance(__uuidof(Command));

 

        pCommand->ActiveConnection &#61; m_OraDateBase.m_pConnection;//连接字符串

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

 

        _variant_t vt;

        vt.SetString("2");

        _ParameterPtr pParampParam1;

        pParam.CreateInstance(__uuidof(Parameter));

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

        pParam->Value &#61; _variant_tstrKey.c_str() );

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

    

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

 

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

 

        //iExpVal &#61; 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 &#61; 0;

        //shGameCoin &#61; 0;

        return ;

    }

 

    return ;

}

 

 

【参考】

程序中调用的ADO函数的具体可用参数值可参考以下文档&#xff1a;

Microsoft ADO 程序员参考

http://www.yesky.com/imagesnew/software/ado/index.html

C&#43;&#43;中的Parameter类型和ADO的类型换转

http://blog.sina.com.cn/s/blog_53061af00100miqs.html 

 

VC ADO
http://www.pconline.com.cn/pcedu/empolder/gj/vc/0507/653859.html
http://www.vckbase.com/document/viewdoc/?id&#61;496
http://zhidao.baidu.com/question/87587746.html
http://bbs.blueidea.com/thread-2007722-1-1.html
http://hi.baidu.com/&#xfffd;&#xfffd;&#xfffd;&#xfffd;&#xfffd;&#xfffd;01/blog/item/a5b0bd0873b9129d0b7b821d.html


本人转载出处&#xff1a;http://blog.sina.com.cn/s/blog_600ce18b0100urzx.html


推荐阅读
  • 本文介绍了一个在线急等问题解决方法,即如何统计数据库中某个字段下的所有数据,并将结果显示在文本框里。作者提到了自己是一个菜鸟,希望能够得到帮助。作者使用的是ACCESS数据库,并且给出了一个例子,希望得到的结果是560。作者还提到自己已经尝试了使用"select sum(字段2) from 表名"的语句,得到的结果是650,但不知道如何得到560。希望能够得到解决方案。 ... [详细]
  • Linux重启网络命令实例及关机和重启示例教程
    本文介绍了Linux系统中重启网络命令的实例,以及使用不同方式关机和重启系统的示例教程。包括使用图形界面和控制台访问系统的方法,以及使用shutdown命令进行系统关机和重启的句法和用法。 ... [详细]
  • Go Cobra命令行工具入门教程
    本文介绍了Go语言实现的命令行工具Cobra的基本概念、安装方法和入门实践。Cobra被广泛应用于各种项目中,如Kubernetes、Hugo和Github CLI等。通过使用Cobra,我们可以快速创建命令行工具,适用于写测试脚本和各种服务的Admin CLI。文章还通过一个简单的demo演示了Cobra的使用方法。 ... [详细]
  • PDO MySQL
    PDOMySQL如果文章有成千上万篇,该怎样保存?数据保存有多种方式,比如单机文件、单机数据库(SQLite)、网络数据库(MySQL、MariaDB)等等。根据项目来选择,做We ... [详细]
  • 本文介绍了一种轻巧方便的工具——集算器,通过使用集算器可以将文本日志变成结构化数据,然后可以使用SQL式查询。集算器利用集算语言的优点,将日志内容结构化为数据表结构,SPL支持直接对结构化的文件进行SQL查询,不再需要安装配置第三方数据库软件。本文还详细介绍了具体的实施过程。 ... [详细]
  • 向QTextEdit拖放文件的方法及实现步骤
    本文介绍了在使用QTextEdit时如何实现拖放文件的功能,包括相关的方法和实现步骤。通过重写dragEnterEvent和dropEvent函数,并结合QMimeData和QUrl等类,可以轻松实现向QTextEdit拖放文件的功能。详细的代码实现和说明可以参考本文提供的示例代码。 ... [详细]
  • CSS3选择器的使用方法详解,提高Web开发效率和精准度
    本文详细介绍了CSS3新增的选择器方法,包括属性选择器的使用。通过CSS3选择器,可以提高Web开发的效率和精准度,使得查找元素更加方便和快捷。同时,本文还对属性选择器的各种用法进行了详细解释,并给出了相应的代码示例。通过学习本文,读者可以更好地掌握CSS3选择器的使用方法,提升自己的Web开发能力。 ... [详细]
  • 本文介绍了九度OnlineJudge中的1002题目“Grading”的解决方法。该题目要求设计一个公平的评分过程,将每个考题分配给3个独立的专家,如果他们的评分不一致,则需要请一位裁判做出最终决定。文章详细描述了评分规则,并给出了解决该问题的程序。 ... [详细]
  • Spring特性实现接口多类的动态调用详解
    本文详细介绍了如何使用Spring特性实现接口多类的动态调用。通过对Spring IoC容器的基础类BeanFactory和ApplicationContext的介绍,以及getBeansOfType方法的应用,解决了在实际工作中遇到的接口及多个实现类的问题。同时,文章还提到了SPI使用的不便之处,并介绍了借助ApplicationContext实现需求的方法。阅读本文,你将了解到Spring特性的实现原理和实际应用方式。 ... [详细]
  • 本文介绍了南邮ctf-web的writeup,包括签到题和md5 collision。在CTF比赛和渗透测试中,可以通过查看源代码、代码注释、页面隐藏元素、超链接和HTTP响应头部来寻找flag或提示信息。利用PHP弱类型,可以发现md5('QNKCDZO')='0e830400451993494058024219903391'和md5('240610708')='0e462097431906509019562988736854'。 ... [详细]
  • 3.223.28周学习总结中的贪心作业收获及困惑
    本文是对3.223.28周学习总结中的贪心作业进行总结,作者在解题过程中参考了他人的代码,但前提是要先理解题目并有解题思路。作者分享了自己在贪心作业中的收获,同时提到了一道让他困惑的题目,即input details部分引发的疑惑。 ... [详细]
  • 本文详细介绍了如何使用MySQL来显示SQL语句的执行时间,并通过MySQL Query Profiler获取CPU和内存使用量以及系统锁和表锁的时间。同时介绍了效能分析的三种方法:瓶颈分析、工作负载分析和基于比率的分析。 ... [详细]
  • 【shell】网络处理:判断IP是否在网段、两个ip是否同网段、IP地址范围、网段包含关系
    本文介绍了使用shell脚本判断IP是否在同一网段、判断IP地址是否在某个范围内、计算IP地址范围、判断网段之间的包含关系的方法和原理。通过对IP和掩码进行与计算,可以判断两个IP是否在同一网段。同时,还提供了一段用于验证IP地址的正则表达式和判断特殊IP地址的方法。 ... [详细]
  • 本文介绍了在iOS开发中使用UITextField实现字符限制的方法,包括利用代理方法和使用BNTextField-Limit库的实现策略。通过这些方法,开发者可以方便地限制UITextField的字符个数和输入规则。 ... [详细]
  • 本文介绍了绕过WAF的XSS检测机制的方法,包括确定payload结构、测试和混淆。同时提出了一种构建XSS payload的方法,该payload与安全机制使用的正则表达式不匹配。通过清理用户输入、转义输出、使用文档对象模型(DOM)接收器和源、实施适当的跨域资源共享(CORS)策略和其他安全策略,可以有效阻止XSS漏洞。但是,WAF或自定义过滤器仍然被广泛使用来增加安全性。本文的方法可以绕过这种安全机制,构建与正则表达式不匹配的XSS payload。 ... [详细]
author-avatar
时刻要有危机感01
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有