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

tzo*_*zik 5 java mysql spring hibernate jpa

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

select * from users;
Run Code Online (Sandbox Code Playgroud)

如何@Procedure在 a 中使用注释JpaRepository以便获得结果?就像是:

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

Vla*_*cea 3

假设这是您的程序:

CREATE PROCEDURE get_users()
BEGIN
    SELECT * FROM USERS;
END
Run Code Online (Sandbox Code Playgroud)

您定义一个@NamedStoredProcedureQuery

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

然后你可以这样调用你的程序:

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

您还可以使用 EntityManager 来检查这一点,如下所示:

Query query = entitymanager.createNamedQuery("getUsers");
List users = query.getResultList();
Run Code Online (Sandbox Code Playgroud)