首页 > 代码库 > C++完毕Oracle存储过程批量插入(二)
C++完毕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;
C++完毕Oracle存储过程批量插入(二)
声明:以上内容来自用户投稿及互联网公开渠道收集整理发布,本网站不拥有所有权,未作人工编辑处理,也不承担相关法律责任,若内容有误或涉及侵权可进行投诉: 投诉/举报 工作人员会在5个工作日内联系你,一经查实,本站将立刻删除涉嫌侵权内容。