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)
假设这是您的程序:
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)
| 归档时间: |
|
| 查看次数: |
4655 次 |
| 最近记录: |