首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >问答首页 >Java Spring projection内部投影

Java Spring projection内部投影
EN

Stack Overflow用户
提问于 2018-02-27 03:28:42
回答 2查看 647关注 0票数 2

是否可以使用投影,并在某些相关对象中使用它自己的投影?

例如,一个有List<Question>的have Exam。我想请求检查列表(我有一个@projection),但是我想为每个相关的Question定义要检索的属性

EN

回答 2

Stack Overflow用户

回答已采纳

发布于 2018-04-12 22:42:42

如果我理解正确的话,您希望使用Projection作为Projection的子级。如果是这样的话,是的,你可以。您可以创建一个QuestionProjection并在ExamProjection内部使用。

示例:

代码语言:javascript
运行
复制
@Projection(name = "questionProjection", types = { Question.class }) 
public interface QuestionProjection {
    // Getters
}

@Projection(name = "examProjection", types = { Exam.class }) 
public interface ExamProjection {
    List<QuestionProjection> getQuestionList();

    // Other Getters
}
票数 3
EN

Stack Overflow用户

发布于 2020-01-12 09:04:43

你可以这样做:

假设您的Exam实体可能是:

代码语言:javascript
运行
复制
@Entity
@Table(name = "EXAM")
public class Exam implements Serializable {

    private static final long serialVersionUID = 1L;

    @Id
    @GeneratedValue(strategy = GenerationType.IDENTITY)
    @Column(name = "ID")
    private Long id;

    @Column(name = "DESCR")
    private String descr;

    @OneToMany(mappedBy = "exam")
    private List<Question> questions;

      // Getters and Setters

和您的Question实体

代码语言:javascript
运行
复制
@Entity
@Table(name = "QUESTION")
public class Question implements Serializable {

    private static final long serialVersionUID = 1L;

    @Id
    @GeneratedValue(strategy = GenerationType.IDENTITY)
    @Column(name = "ID")
    private Long id;

    @Column(name = "DESCR")
    private String descr;

    @Column(name = "CONT")
    private String cont;

    @ManyToOne
    @JoinColumn(name = "EXAM_ID")
    @JsonIgnoreProperties("questions")
    private Exam exam;

因此,创建投影

代码语言:javascript
运行
复制
public interface ExamProjection {
    Long getId();

    String getDescr();

    List<QuestionProjection> getQuestions();
}

代码语言:javascript
运行
复制
public interface QuestionProjection {
    Long getId();

    String getDescr();
}

您的存储库

代码语言:javascript
运行
复制
@Repository
public interface ExamRepository extends JpaRepository<Exam, Long> {

    List<Exam> findAll();

    @Query("SELECT e FROM Exam e")
    List<ExamProjection> findAllProjection();
}

注意到,由于某些原因,使用findAll()方法并将列表类型作为ExamProjection传递会导致不兼容的返回类型错误。要避免这种情况,请创建一个自定义方法,在本例中为findAllProjection()

服务

代码语言:javascript
运行
复制
@Service
public class ExamService {

    @Autowired
    ExamRepository examRepository;

    public List<ExamProjection> findAllProjection() {
        return examRepository.findAllProjection();
    }
}

最后,资源

代码语言:javascript
运行
复制
@RestController
@RequestMapping(value = "/exam")
public class ExamResource {

    @Autowired
    ExamService examService;

    @GetMapping
    public ResponseEntity<List<ExamProjection>> findAll() {
        return ResponseEntity.ok().body(examService.findAllProjection());
    }
}

使用上面的方法,返回的json不包含字段cont,因为de QuestionProjection没有getCont()方法。

代码语言:javascript
运行
复制
[
    {
        "id": 1,
        "descr": "First Exam",
        "questions": [
            {
                "id": 1,
                "descr": "First Question"
            },
            {
                "id": 2,
                "descr": "Second Question"
            }
        ]
    }
]

如果QuestionProjection更改为

代码语言:javascript
运行
复制
public interface QuestionProjection {
    Long getId();

    String getCont();
}

json将更改返回给

代码语言:javascript
运行
复制
[
    {
        "id": 1,
        "descr": "First Exam",
        "questions": [
            {
                "id": 1,
                "cont": "First Question Content"
            },
            {
                "id": 2,
                "cont": "Second Question Content"
            }
        ]
    }
]
票数 2
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/48995744

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档