Определение @JoinFormula и @OneToMany - плохая документация - PullRequest
28 голосов
/ 31 марта 2012

У меня есть два вопроса, касающихся аннотаций @JoinFormula и @OneToMany:

  1. Как ограничить количество результатов с аннотациями @JoinFormula и @OneToMany?

  2. Как я могу определить, что id в выражении author = id относится к Author.id?

    Author {
    
        @Id
        private Long id;
    
        @OneToMany
        @JoinFormula(value = "SELECT a FROM Article a WHERE author = id AND schedule < CURRENT_TIMESTAMP()") // limit = 15
        private List<Article> pastArticles;
    }
    

Таким образом, я сохраняю pastArticles пустым, даже когда я удаляю schedule < часть предложения.

Спасибо!

Ответы [ 2 ]

13 голосов
/ 14 декабря 2012

Ответ 1:

@Size(max=10)
private List<Comment> commentList;

Ответ 2: (просто пример как этот)

public class A{

    @Id
    @GeneratedValue
    private Integer id;

    private String uuid;

    ...
  }

другой класс

public class B{
      @Id 
      @GeneratedValue
      private Integer id;

      private String uuidOfA;



  @ManyToOne
  @JoinColumnsOrFormulas({
  @JoinColumnOrFormula(formula=@JoinFormula(value="(SELECT a.id FROM A a WHERE a.uuid = uuid)", referencedColumnName="id")),
  @JoinColumnOrFormula(column = @JoinColumn("uuidOfA", referencedColumnName="uuid"))
})

     private A a;      
}
1 голос
/ 02 сентября 2012

вам лучше использовать аннотацию @Where, чтобы ограничить результаты

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...