Spring Data JPA调用存储过程实例

分享一下我老师大神的人工智能教程!零基础,通俗易懂!http://blog.csdn.net/jiangjunshow

也欢迎大家转载本篇文章。分享知识,造福人民,实现我们中华民族伟大复兴!

                       

Spring Data JPA调用存储过程实例

作者:chszs,未经博主允许不得转载。经许可的转载需注明作者和博客主页:http://blog.csdn.net/chszs

JPA连接到数据库,调用存储过程,这样的需求很常见。本文就针对这一点,讲述如何使用Spring Data JPA调用存储过程的方法。

1、存储过程

假设存储过程如下:

CREATE OR REPLACE PACKAGE test_pkg AS   PROCEDURE in_only_test (inParam1 IN VARCHAR2);   PROCEDURE in_and_out_test (inParam1 IN VARCHAR2, outParam1 OUT VARCHAR2);END test_pkg;/CREATE OR REPLACE PACKAGE BODY test_pkg AS   PROCEDURE in_only_test(inParam1 IN VARCHAR2) AS   BEGIN      DBMS_OUTPUT.PUT_LINE('in_only_test');   END in_only_test;   PROCEDURE in_and_out_test(inParam1 IN VARCHAR2, outParam1 OUT VARCHAR2) AS   BEGIN      outParam1 := 'Woohoo Im an outparam, and this is my inparam ' || inParam1;   END in_and_out_test;END test_pkg;
  
  
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11
  • 12
  • 13
  • 14
  • 15

这里有两个存储过程:

1)in_only_test
它需要一个输入参数inParam1,但不返回值

2)in_and_out_test
它需要一个输入参数inParam1,且返回值outParam1

2、@NamedStoredProcedureQueries

我们可以使用@NamedStoredProcedureQueries注释来调用存储过程。

@Entity@Table(name = "MYTABLE")@NamedStoredProcedureQueries({        @NamedStoredProcedureQuery(name = "in_only_test", procedureName = "test_pkg.in_only_test", parameters = {                @StoredProcedureParameter(mode = ParameterMode.IN, name = "inParam1", type = String.class) }),        @NamedStoredProcedureQuery(name = "in_and_out_test", procedureName = "test_pkg.in_and_out_test", parameters = {                @StoredProcedureParameter(mode = ParameterMode.IN, name = "inParam1", type = String.class),                @StoredProcedureParameter(mode = ParameterMode.OUT, name = "outParam1", type = String.class) }) })public class MyTable implements Serializable {}
  
  
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10

关键要点:

  • 存储过程使用了注释@NamedStoredProcedureQuery,并绑定到一个JPA表。
  • procedureName是存储过程的名字
  • name是JPA中的存储过程的名字
  • 使用注释@StoredProcedureParameter来定义存储过程使用的IN/OUT参数

3、创建Spring Data JPA数据库

下面我们来创建Spring Data JPA数据库:

public interface MyTableRepository extends CrudRepository<MyTable, Long> {    @Procedure(name = "in_only_test")    void inOnlyTest(@Param("inParam1") String inParam1);    @Procedure(name = "in_and_out_test")    String inAndOutTest(@Param("inParam1") String inParam1);}
  
  
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7

关键要点:

  • @Procedure的name参数必须匹配@NamedStoredProcedureQuery的name
  • @Param必须匹配@StoredProcedureParameter注释的name参数
  • 返回类型必须匹配:in_only_test存储过程返回是void,in_and_out_test存储过程必须返回String

4、调用

我们可以这样调用存储过程:

    // 向存储过程传递参数并返回值    String inParam = "Hi Im an inputParam";    String outParam = myTableRepository.inAndOutTest(inParam);    Assert.assertEquals(outParam, "Woohoo Im an outparam, and this is my inparam Hi Im an inputParam");    // 向存储过程传递参数不返回值    myTableRepository.inOnlyTest(inParam);
  
  
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6

5、其它技巧

如果上面的代码不工作,可以这么解决。定义自定义的Repository来调用存储过程昨晚本地查询。

定义自定义的Repository:

public interface MyTableRepositoryCustom {    void inOnlyTest(String inParam1);}
  
  
  • 1
  • 2
  • 3

然后要确保主Repository类继承了这个接口。

public interface MyTableRepository extends CrudRepository<MyTable, Long>, MyTableRepositoryCustom {}
  
  
  • 1
  • 2

6、创建Repository实现类

接着该创建Repository实现类了:

public class MyTableRepositoryImpl implements MyTableRepositoryCustom {
    @PersistenceContext
    private EntityManager em;

@Overridepublic void inOnlyTest(String inParam1) {    this.em.createNativeQuery("BEGIN in_only_test(:inParam1); END;").setParameter("inParam1", inParam1)            .executeUpdate();}
  
  
  • 1
  • 2
  • 3
  • 4
  • 5

}

可以以常规的方式进行调用:

@AutowiredMyTableRepository myTableRepository;// 调用存储过程myTableRepository.inOnlyTest(inParam1);
  
  
  • 1
  • 2
  • 3
  • 4

是不是很简单。

           

给我老师的人工智能教程打call!http://blog.csdn.net/jiangjunshow
这里写图片描述
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值