gpt4 book ai didi

Ebean:如何在 LEFT OUTER JOIN 中过滤右表

转载 作者:行者123 更新时间:2023-12-02 04:56:12 24 4
gpt4 key购买 nike

我想像这样用 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/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com