设为首页 加入收藏

TOP

C++完成Oracle存储过程批量插入(二)
2015-07-20 17:46:37 来源: 作者: 【 】 浏览:1
Tags:完成 Oracle 存储 过程 批量 插入

上篇文章简单的介绍了一下oracle参数是Object类型的数据库存储过程,以及JAVA使用JDBC去调用该类的存储过程的方法。但是我需要的是C++下的方案,使用Poco库未发现任何可以调用该类型存储过程的方法,但是功能还是需要实现的,后来发现Oracle支持XML的解析,于是有了下面的方案,即存储过程的参数为CLOB类型,C++按照传入XML格式字符串的方式调用存储过程,在存储过程中解析xml后,将数据插入数据库中。

(有了上述的方案后,我猜想JDBC的处理方式可能也是往Oracle数据库中传入XML格式的字符串,Oracle内部可以实现XML到Object对象的转换,最后往存储过程中传入该Object参数)

下面为该方案的主要代码:

1)Oracle存储过程

create or replace procedure POCO_TEST_XML_CLOB_PRO(v_xml in CLOB) is
begin
  INSERT INTO POCO_TEST(ID,name,code)
  SELECT * FROM XMLTABLE('$B/Parment/PocoTest' PASSING
    XMLTYPE(v_xml) AS B
    COLUMNS ID VARCHAR2(50) PATH
    '/PocoTest/ID',
    NAME VARCHAR2(50) PATH
    '/PocoTest/Name',
    CODE VARCHAR2(50) PATH
    '/PocoTest/Code');
end POCO_TEST_XML_CLOB_PRO;

2)C++代码的调用

	std::string str;
	ODBCObject::getCollectionXmlStr(str,arr);
	Poco::Data::CLOB clob(str.c_str(),str.size());
	session << "{call POCO_TEST_XML_CLOB_PRO(?)}", Poco::Data::Keywords::in(clob),  Poco::Data::Keywords::now;


这里是完整工程代码的 下载地址。

】【打印繁体】【投稿】【收藏】 【推荐】【举报】【评论】 【关闭】 【返回顶部
分享到: 
上一篇uva 11475 - Extend to Palindrom.. 下一篇uva 1519 - Dictionary Size(字典..

评论

帐  号: 密码: (新用户注册)
验 证 码:
表  情:
内  容:

·C语言中如何将结构体 (2025-12-24 22:20:09)
·纯C语言结构体成员变 (2025-12-24 22:20:06)
·C语言中,指针函数和 (2025-12-24 22:20:03)
·哈希表 - 菜鸟教程 (2025-12-24 20:18:55)
·MySQL存储引擎InnoDB (2025-12-24 20:18:53)