簡體   English   中英

修改Spring Data REST投影背后生成的SQL查詢

[英]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 ,其具有字段foobarzed

您應該為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.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM