[英]Modify SQL query generated behind Spring Data REST projections
編輯:如何在SELECT數據中僅保留所需的列以進行Spring Data Rest預測?
Spring Data Rest Projections適用於為生成的鏈接獲取列的子集,但在后面生成的Query仍然包含其中的所有列。
如何創建預測,其中SQL查詢只有SELECT中的那些列在Projection中
我不知道為什么文檔中缺少它,但是這個春季樣本(來自spring)表明你可以使用projection作為@Query的返回類型。 所以你可以這樣做:
public interface ActionId {
String getId();
}
@Query("select a.id as id from Action a where a.type = :type")
public List<ActionId> findByType(@Param("type") String type);
現在,您可以更簡潔地選擇所需的列,並返回一個對象,而不必使用構造函數表達式。 我希望這些投影可以應用於域對象本身,因此您仍然可以返回僅包含id字段的“Action”,但現在看起來不可能 -
參考: https : //github.com/spring-projects/spring-data-examples/blob/master/jpa/example/src/main/java/example/springdata/jpa/projections/CustomerRepository.java
我想你可以使用“嵌套投影”。
示例:資源A
包含字段bubi
和資源B
,其具有字段foo
, bar
, zed
。
您應該為B
創建一個投影,只列出您想要的字段:
@Projection(name="reduced", types = B.class)
public interface BReduced {
String foo;
//exclude bar, for instance
int zed;
}
然后在A
的投影中使用該投影。
@Projection(name="reduced", types = A.class)
public interface AReduced {
int bubi;
BReduced b;
}
我是否感覺不好,或者您是在談論SQL查詢中的性能?
聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.