gpt4 book ai didi

mysql - 如何为 JPA View 实体传递动态限制值?

转载 作者:行者123 更新时间:2023-11-29 16:30:46 24 4
gpt4 key购买 nike

我在 MySQL 中创建了一个 View ,并在 JPA 中使用该 View 作为实体,

@Entity
@Immutable
@Table(name = "my_view")

现在我面临的问题是我试图通过在查询对象中设置 setMaxResults 来进行分页,在后端发生的情况是 View 没有限制,因此它尝试获取所有记录,然后它应用了 setMaxResults,这会降低性能,我本来可以编写 native 查询,但它有点困惑。

生成的查询将如下所示

select e from myViewEntity where 1=1 and (adding addition constraints as parameter)

我的问题是有什么方法可以将 Limit 作为动态值传递给 View ?

Note: I am passing constraints to the view by using alias name.

最佳答案

您可以通过动态传递firstResult和maxResults的值,在查询中使用setFirstResultsetMaxResults方法,如下所示。

List<User> users = entityManager().createQuery("SELECT o FROM User o", User.class).setFirstResult(firstResult).setMaxResults(maxResults).getResultList();

关于mysql - 如何为 JPA View 实体传递动态限制值?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/53940233/

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