作者热门文章
- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我想像这样用 Ebean 创建一个查询:
SELECT
t0.book_id, t0.name, t1.accno
FROM
books t0
LEFT OUTER JOIN
external_refs t1 ON t0.book_id = t1.book_id AND t1.type = "doi"
WHERE
t0.book_id in (1, 2, 3, 4)
实体“书”包含一对多关系
@OneToMany(cascade = CascadeType.ALL)
@JoinColumn(name="book_id", referencedColumnName = "book_id")
public List<ExternalRef> externalRefs;
这就是我创建查询的方式:
List<Integer> bookIds;
Query<Book> query = Ebean.createQuery(Book.class).where(Expr.in("book_id", bookIds));
如何将 AND t1.type = "doi"
部分添加到此查询?
最佳答案
我认为无法改进您的查询以满足您的要求。但是我构建了不同的返回期望结果的。这是代码:
Query<ExternalRef> queryER = Ebean.createQuery(ExternalRef.class).where(Expr.and (Expr.eq("type", "doi"), Expr.in("book.book_id", bookIds) ));
所以我查询的不是 Books,而是 ExternalRefs。
关于Ebean:如何在 LEFT OUTER JOIN 中过滤右表,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/22014780/
我是一名优秀的程序员,十分优秀!