注解 @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.
