我目前正在开发一个使用queryDSL和hibernate的项目,其中需要一个select文字。根据{{3}}发布的示例,我有:
createQuery().
from(path()).
where(specification().getPredicate()).
list(
ConstructorExpression.create(Foo.class, Expressions.constant(BigDecimal.ONE)));
其中Foo类有一个接受BigDecimal的构造函数。 在测试中运行时,我得到了
org.hibernate.QueryException: Parameters are only supported in SELECT clauses when used as part of a INSERT INTO DML statement
at org.hibernate.hql.internal.ast.tree.SelectClause.initializeExplicitSelectClause(SelectClause.java:146)
将此更改为:
createQuery()
.from(path()).
where(specification().getPredicate())
.list(
ConstructorExpression.create(Foo.class, NumberTemplate.create(BigDecimal.class, "1.0")));
产生不同的堆栈跟踪:
java.lang.IllegalArgumentException: argument type mismatch
at sun.reflect.NativeConstructorAccessorImpl.newInstance0(Native Method)
at sun.reflect.NativeConstructorAccessorImpl.newInstance(NativeConstructorAccessorImpl.java:57)
at sun.reflect.DelegatingConstructorAccessorImpl.newInstance(DelegatingConstructorAccessorImpl.java:45)
at java.lang.reflect.Constructor.newInstance(Constructor.java:526)
at com.mysema.query.types.ConstructorExpression.newInstance(ConstructorExpression.java:133)
at com.mysema.query.jpa.FactoryExpressionTransformer.transformTuple(FactoryExpressionTransformer.java:50)
我尝试将Foo类构造函数更改为接受Integer,并且为了测试而修改了查询以使用Integer,它确实产生了正确的查询:
createQuery()
.from(path()).
where(specification().getPredicate())
.list(ConstructorExpression.create(LevelBoundary.class, NumberTemplate.create(Integer.class, "1")));
使用NumberTemplate选择BigDecimal文字的正确方法是什么? NumberTemplate docs指定T扩展Number和Comparable但在非Integer类型上失败。如何在querydsl中正确选择常量/文字?
答案 0 :(得分:0)
我遇到了类似的问题,并向QueryDSL的开发人员询问了相关问题。答案是:"这是Hibernate中的一个错误,我们无法解决这个问题" 。您可能必须使用除Expressions.constant
以外的其他内容才能使其正常工作。
在我的代码中,它使用与此类似的代码:
ConstructorExpression.create(LevelBoundary.class, Expressions.stringTemplate("'1'")