Hibernate 之 @Query查詢


注解  @Query 允許在方法上使用 JPQL。 列如:

@Query("select u from User u where u.name=?1 and u.department_id=?2")

public User findUser(String name,Integer departmentId);

 

如果是使用SQL,而不是JPSQL,可以使用 @Query 的 nativeQuery屬性,設置為true:例如

@Query(value="select * from user  where name=?1 and department_id=?2",nativeQuery=true)

public User findUser(String name,Integer departmentId);

 

還有一種情況是:無論是JPQL還是 SQL,都支持 ‘命名參數’

@Query(value="select * from user  where name=:name and department_id=:departmentId",nativeQuery=true)

public User findUser(String name,Integer departmentId);

 

如果SQL 或者 JPQL查詢的結果集並非 Entity,可以使用Object[]數組代替,比如分組統計每個部分的用戶數

@Query(value="select department_id ,count(*) from user group by depatment_id",nativeQuery=true)

public List<Object[]> queryUserCount();

這條查詢語句返回數組,對象類型依賴查詢結果,本例子中,返回的是String 和 BigInteger 類型

 

 

注意:Spring Data 沒有像BeetlSQL那樣允許將SQL查詢結果映射到一個任意的POJO或者 Map 對象上,因此,對於這種 非實體返回結果,只能使用 Object[] 數組,數組中每個元素的類型要小心處理。 比如count(*) 返回的是BigInteger。在不同的數據庫中,返回的可能是BigDecimal.

 


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM