Giả sử đây là thủ tục của bạn:
CREATE OR REPLACE PROCEDURE get_users(data out SYS_REFCURSOR)
AS
BEGIN
OPEN data FOR SELECT * FROM USERS;
END;
Bạn xác định một @NamedStoredProcedureQuery
:
@NamedStoredProcedureQuery(
name="getUsers",
procedureName="get_users",
resultClass=User.class, parameters={
@StoredProcedureParameter(queryParameter="data", name="data", direction=Direction.OUT_CURSOR)
}
)
@Entity
public class User {
...
}
Và sau đó bạn có thể gọi thủ tục của mình như sau:
public UserRepository extends JpaRepository<User, Long>{
@Procedure('User.getUsers')
List<User> getUsers();
}
Bạn cũng có thể kiểm tra điều này bằng cách sử dụng EntityManager của mình như sau:
Query query = entitymanager.createNamedQuery("getUsers");
List users = query.getResultList();