[亲测可用]hibernate调用Oracle存储过程|Spring Data JPA调用Oracle存储过程方法

简介: [亲测可用]hibernate调用Oracle存储过程|Spring Data JPA调用Oracle存储过程方法

一、前言

我们知道在plsql里可以通过下面方式执行存储过程,

begin P_ACCOUNT(202004270000) ; end;
--或者
call  P_ACCOUNT(202004270000)

但是在代码里如何调用存储过程呢,我试了一些网上大家提供的方法,基本没用效果,包括在@Query后面加{call P_ACCOUNT(?,?)} 什么存储过程名称的,或者各种接口、实现类互相调用的,都是千篇一律,不知道哪家copy哪家的,都没有任何效果 。

或者这些方法对他们的项目可能有用,亦是我的姿势可能不对,但是总的来说,下面这个方法是我亲测可用的,而且实现起来相对更简单,十行代码都不到就能实现


二、调用存储过程Demo

//公众号灵儿的笔记:zygxsq
    @Transactional
  @Modifying
  @Query
  public void callProcedureSend(Long Id){
    logger.info("调用存储过程P_ACCOUNT({})",new Object[]{Id});
    StoredProcedureQuery storedProcedure = em.createStoredProcedureQuery("P_ACCOUNT");
    storedProcedure.registerStoredProcedureParameter("A_ID", Long.class, ParameterMode.IN);
    storedProcedure.registerStoredProcedureParameter("result", String.class, ParameterMode.OUT);
    storedProcedure.setParameter("A_ID", Id);
    boolean execute = storedProcedure.execute();
        //博客原帖链接:https://blog.csdn.net/qq_27471405/article/details/105794591
    //获取返回结果
    String result = storedProcedure.getOutputParameterValue("result").toString();
  }


三、代码说明

P_ACCOUNT :就是在oracle中的存储过程名称


A_ID :就是入参,如果还有其他入参,就再写一行,


storedProcedure.registerStoredProcedureParameter("xxx参数", 参数类型, ParameterMode.IN);


我这里的入参id是一个number类型,所以这里用Long.class,如果是char类型,这里就用String.class


result:这里是自定义一个返回值的参数名称,如果存储过程有返回值返回,就加这行代码,如果没有的话,就不需要加这两行了

storedProcedure.registerStoredProcedureParameter("result", String.class, ParameterMode.OUT);


String result = storedProcedure.getOutputParameterValue("result").toString();

相关文章
|
1月前
|
XML JSON Java
使用IDEA+Maven搭建整合一个Struts2+Spring4+Hibernate4项目,混合使用传统Xml与@注解,返回JSP视图或JSON数据,快来给你的SSH老项目翻新一下吧
本文介绍了如何使用IntelliJ IDEA和Maven搭建一个整合了Struts2、Spring4、Hibernate4的J2EE项目,并配置了项目目录结构、web.xml、welcome.jsp以及多个JSP页面,用于刷新和学习传统的SSH框架。
31 0
使用IDEA+Maven搭建整合一个Struts2+Spring4+Hibernate4项目,混合使用传统Xml与@注解,返回JSP视图或JSON数据,快来给你的SSH老项目翻新一下吧
|
17天前
|
Java 数据库连接 数据库
携手前行:在Java世界中深入挖掘Hibernate与JPA的协同效应
【8月更文挑战第31天】Java持久化API(JPA)是一种Java规范,为数据库数据持久化提供对象关系映射(ORM)方法。JPA定义了实体类与数据库表的映射及数据查询和事务控制方式,确保不同实现间的兼容性。Hibernate是JPA规范的一种实现,提供了二级缓存、延迟加载等丰富特性,提升应用性能和可维护性。通过结合JPA和Hibernate,开发者能编写符合规范且具有高度可移植性的代码,并利用Hibernate的额外功能优化数据持久化操作。
31 0
|
27天前
|
Java 数据库连接 数据库
Spring Data JPA 与 Hibernate 之区别
【8月更文挑战第21天】
17 0
|
27天前
|
SQL Java 数据库连接
Hibernate 和 JPA 有什么区别?
【8月更文挑战第21天】
67 0
|
27天前
|
Java 数据库连接 数据库
|
27天前
|
缓存 Java 数据库连接
|
27天前
|
Java 数据库连接 API
|
27天前
|
Java 数据库连接 应用服务中间件
|
2月前
|
SQL Oracle 关系型数据库
关系型数据库Oracle Data Guard
【7月更文挑战第11天】
24 1

推荐镜像

更多