mybatis调用oracle存储过程

有输入与输出参数的存储过程

创新互联公司10多年成都企业网站建设服务;为您提供网站建设,网站制作,网页设计及高端网站定制服务,成都企业网站建设及推广,对成都除甲醛等多个行业拥有多年的网站制作经验的网站建设公司。

oracle存储过程部分代码:

create or replace procedure PT_copy_Shipment_One_Data(

  oldShipmentId in  varchar ,

  servprovGid in varchar ,

  insertUser in varchar,

  resultShipmentId out varchar

)is

 newShipmentGid varchar2(50 );

 newShipmentXid varchar2(50 );

 newShipmentTypeGid varchar2(50 );

begin

          --执行的PLSQL体

commit;--提交事物

Exception

   When others then

      Rollback;

end  PT_copy_Shipment_One_Data;



mybatis的Xml配置

注意:虽然有返回值,不需要知道设置返回参数类,详情可看下面java代码例子


"callCoptShipment" parameterType ="map"  

           statementType="CALLABLE">

    

{call PT_copy_Shipment_One_Data(

#{oldShipmentId,mode=IN,jdbcType=VARCHAR},

#{servprovGid,mode=IN,jdbcType=VARCHAR},

#{insertUser,mode=IN,jdbcType=VARCHAR},

#{resultShipmentId,mode=OUT,jdbcType=VARCHAR}

)} 

     ]]> 


Dao或者Service代码


Map parasMap = new HashMap();

parasMap.put("oldShipmentId", para.get( "shipmentId"));

parasMap.put( "servprovGid", para.get("skdw"));//attr12

parasMap.put( "insertUser", Users.getCurrent());

parasMap.put( "resultShipmentId", "" );

//调用存储过程

  this.getSqlSessionTemplate().

selectOne("com.otm.app.entity.pojo.ShipmentCost.callCoptShipment",parasMap);

parasMap.put("shipmentId", parasMap.get("resultShipmentId" ));

return parasMap;


如上标红的代码,在mybatis不需要设置返回参数,然后在java当中调用存储过程也不需要接受返回参数,map参数当中会自动有。这是一个奇怪的地方。

                                                                       交流技术群号:50567913


分享标题:mybatis调用oracle存储过程
分享链接:http://hxwzsj.com/article/ghecdj.html

其他资讯

Copyright © 2025 青羊区翔捷宏鑫字牌设计制作工作室(个体工商户) All Rights Reserved 蜀ICP备2025123194号-14
友情链接: 成都网站设计制作公司 成都网站建设 营销型网站建设 高端品牌网站建设 达州网站设计 成都网站设计 高端网站设计 成都企业网站设计 成都网站建设 网站设计 成都网站制作 成都企业网站制作 重庆网站制作 阿坝网站设计 成都网站建设 移动网站建设 专业网站设计 成都网站建设 手机网站设计 手机网站制作设计 手机网站建设 商城网站建设