如何通过使用Spring Data调用存储过程来选择实体 [英] How to select entities by calling a strored procedure with Spring Data

查看:148
本文介绍了如何通过使用Spring Data调用存储过程来选择实体的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着小编来一起学习吧!

问题描述

假设我有一个MySQL存储过程,它包含以下select:

  select * from users; 

如何使用 @Procedure 注释一个 JpaRepository 以便我可以得到结果?例如:

  public UserRepository extenda JpaRepository< User,Long> {
@Procedure('get_users')
列表<用户> getUsers();


解决方案

假设这是您的程序:
$ b $ pre $ CREATE OR REPLACE PROCEDURE get_users(data out SYS_REFCURSOR)
AS
BEGIN
OPEN数据FOR SELECT * FROM USERS;
END;

您定义了一个 @NamedStoredProcedureQuery :< @

  @NamedStoredProcedureQuery(
name =getUsers,
procedureName =get_users,
resultClass = User.class,参数= {
@StoredProcedureParameter(queryParameter =data,name =data,direction = Direction.OUT_CURSOR)
}

@Entity
public class User {
...
}

然后你可以这样调用你的过程:
$ b $ pre $ public UserRepository扩展JpaRepository< User,Long> {
@Procedure(' User.getUsers')
List< User> getUsers();

$ / code>

你也可以使用你的EntityManager来检查:

 查询查询= entitymanager.createNamedQuery(getUsers); 
List users = query.getResultList();


Let's say I have a MySQL stored procedure that contains the following select:

select * from users;

How to use the @Procedure annotation in a JpaRepository so that I can get the results? Something like:

public UserRepository extenda JpaRepository<User, Long>{
    @Procedure('get_users')
    List<User> getUsers();
}

解决方案

Let's say this is your procedure:

CREATE OR REPLACE PROCEDURE get_users(data out SYS_REFCURSOR)
AS
BEGIN
OPEN data FOR SELECT * FROM USERS;
END;

You define a @NamedStoredProcedureQuery:

@NamedStoredProcedureQuery(
    name="getUsers", 
    procedureName="get_users", 
    resultClass=User.class, parameters={
        @StoredProcedureParameter(queryParameter="data", name="data", direction=Direction.OUT_CURSOR)
    }
)
@Entity
public class User {
    ...
}

And then you can call your procedure like this:

public UserRepository extends JpaRepository<User, Long>{
    @Procedure('User.getUsers')
    List<User> getUsers();
}

You can also check this using your EntityManager like this:

Query query = entitymanager.createNamedQuery("getUsers");
List users = query.getResultList();

这篇关于如何通过使用Spring Data调用存储过程来选择实体的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持IT屋!

查看全文
登录 关闭
扫码关注1秒登录
发送“验证码”获取 | 15天全站免登陆