gpt4 book ai didi

java - QueryDSL 4 与 RowNumber Window 功能

转载 作者:行者123 更新时间:2023-12-01 12:06:39 29 4
gpt4 key购买 nike

我正在使用带有 Spring 数据的查询 dsl。

环境:

    <querydsl-apt.version>4.1.4</querydsl-apt.version>
<querydsl-jpa.version>4.1.4</querydsl-jpa.version>
<querydsl-sql.version>4.1.4</querydsl-sql.version>
<spring>4.3.3.RELEASE</spring>

询问:
JPAQueryFactory query = new JPAQueryFactory(getEntityManager());

SimpleExpression<Long> rowNumber = SQLExpressions.rowNumber()
.over()
.orderBy(qServiceExecution.updatedAt.asc()).as("rowNumber");

List<Tuple> response = query.select(qServiceExecution.id, SQLExpressions.rowNumber()
.over()
.orderBy(qServiceExecution.updatedAt.asc()))
.from(qServiceExecution)
.fetch();

异常(exception):
Root cause: java.lang.IllegalArgumentException: No pattern found for ROWNUMBER
at com.querydsl.core.support.SerializerBase.visitOperation(SerializerBase.java:280) ~[querydsl-core-4.1.4.jar:na]
at com.querydsl.jpa.JPQLSerializer.visitOperation(JPQLSerializer.java:437) ~[querydsl-jpa-4.1.4.jar:na]
at com.querydsl.core.support.SerializerBase.visit(SerializerBase.java:231) ~[querydsl-core-4.1.4.jar:na]
at com.querydsl.core.support.SerializerBase.visit(SerializerBase.java:31) ~[querydsl-core-4.1.4.jar:na]



Spring error: No pattern found for ROWNUMBER; nested exception is java.lang.IllegalArgumentException: No pattern found for ROWNUMBER
at org.springframework.orm.jpa.EntityManagerFactoryUtils.convertJpaAccessExceptionIfPossible(EntityManagerFactoryUtils.java:384) ~[spring-orm-4.3.3.RELEASE.jar:4.3.3.RELEASE]
at org.springframework.orm.jpa.vendor.HibernateJpaDialect.translateExceptionIfPossible(HibernateJpaDialect.java:246) ~[spring-orm-4.3.3.RELEASE.jar:4.3.3.RELEASE]
at org.springframework.orm.jpa.AbstractEntityManagerFactoryBean.translateExceptionIfPossible(AbstractEntityManagerFactoryBean.java:491) ~[spring-orm-4.3.3.RELEASE.jar:4.3.3.RELEASE]
at org.springframework.dao.support.ChainedPersistenceExceptionTranslator.translateExceptionIfPossible(ChainedPersistenceExceptionTranslator.java:59) ~[spring-tx-4.3.3.RELEASE.jar:4.3.3.RELEASE]
at org.springframework.dao.support.DataAccessUtils.translateIfNecessary(DataAccessUtils.java:213) ~[spring-tx-4.3.3.RELEASE.jar:4.3.3.RELEASE]

查询 DSL 文档: http://www.querydsl.com/static/querydsl/latest/reference/html/ch02s03.html#d0e1276

其他堆栈溢出问题: QueryDSL Window functions

有什么建议吗?

最佳答案

窗口函数不包含在 JPQL 规范中,因此在任何 JPA 实现中都不可用。您可以使用 custom functions 自己注册这些功能。 .

但是,在此之后,这些功能仍然无法在 QueryDSL 中访问。你在偷SQLExpressions在这里获得一个窗口表达式。这些方法生活在SQLExpressions有一个原因:它们只适用于 querydsl-sql而不是 querydsl-jpa (再次,因为 JPA 本身不支持窗口函数)。所以在注册你的自定义函数之后,你仍然需要扩展 JPQLTemplates包含自定义窗口功能的模板。

你会这样做:

public class MyTemplates extends JPQLTemplates {

public MyTemplates() {
add(SQLOps.ROWNUMBER, "ROW_NUMBER({0})");
}

}

然后按如下方式使用它:

new JPAQuery(entityManager, new MyTemplates()).from(entity).select(rowNumber())

然而,由于中间有 Spring 集成,我认为模板更难以绑定(bind)到查询。

或者,您可以查看 blaze-persistence-querydsl 扩展,它对 JPQL 的窗口函数(和许多其他特性)提供了开箱即用的支持。例如:

QCat cat = QCat.cat;

BlazeJPAQuery<Tuple> query = new BlazeJPAQuery<Tuple>(entityManager, criteriaBuilderFactory).from(cat)
.select(cat.name, JPQLNextExpressions.rowNumber(), JPQLNextExpressions.lastValue(cat.name).over().partitionBy(cat.id));

List<Tuple> fetch = query.fetch();

关于java - QueryDSL 4 与 RowNumber Window 功能,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/40744385/

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