假设我有一个包含以下选择的 MySQL 存储过程:
select * from users;
如何在 JpaRepository
中使用 @Procedure
注释以便我可以获得结果?像这样的东西:
public UserRepository extenda JpaRepository<User, Long>{
@Procedure('get_users')
List<User> getUsers();
}
最佳答案
假设这是您的程序:
CREATE PROCEDURE get_users()
BEGIN
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();
关于java - 如何通过使用 Spring Data 调用存储过程来选择实体,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/30578089/