如何通过使用Spring Data调用存储过程来选择实体

时间:2015-06-01 16:03:01

标签: java mysql spring hibernate jpa

假设我有一个MySQL存储过程,其中包含以下选择:

select * from users;

如何在@Procedure中使用JpaRepository注释,以便我可以获得结果?类似的东西:

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

1 个答案:

答案 0 :(得分:3)

让我们说这是你的程序:

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

您定义了@NamedStoredProcedureQuery

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

然后你可以这样打电话给你的程序:

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

您也可以使用您的EntityManager进行检查:

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