我有这个规范:
public static Specification<CompensationCase> containsClaimantName(final String firstName, final String middleName, final String surName, final String motherMaidenName) {
return new Specification<CompensationCase>() {
public Predicate toPredicate(Root<CompensationCase> root, CriteriaQuery<?> query, CriteriaBuilder cb) {
Path<Claimant> claimantPath = root.get(CompensationCase_.claimant);
Subquery<ClaimantPerson> claimantPersonSubquery = query.subquery(ClaimantPerson.class);
Root<ClaimantPerson> claimantPersonRoot = claimantPersonSubquery.from(ClaimantPerson.class);
claimantPersonSubquery.
select(claimantPersonRoot).
where(
ClaimantPersonSpecs
.containsPersonName(firstName, middleName, surName, motherMaidenName)
.toPredicate(claimantPersonRoot, query, cb));
return cb.in(claimantPath.as(ClaimantPerson.class)).value(claimantPersonSubquery);
}
};
}
ClaimantPerson
继承自Claimant
的位置。我读过你可以使用.as()
投射,但我不确定我是否正确行事。目前我收到此错误:
--Erroring: batchId[2] message[java.lang.IllegalArgumentException: org.hibernate.hql.internal.ast.QuerySyntaxException: expecting CLOSE, found '.' near line 1, column 137 [select generatedAlias0 from test.project.compensation.model.CompensationCase as generatedAlias0 where cast(generatedAlias0.claimant as test.project.compensation.model.ClaimantPerson) in (select generatedAlias1 from test.project.compensation.model.ClaimantPerson as generatedAlias1 where generatedAlias1.personRef in (select generatedAlias2 from test.project.entity.identity.PersonRef as generatedAlias2 where ( ( ( lower(generatedAlias2.name.firstName) like :param0 ) and ( 1=1 ) ) and ( lower(generatedAlias2.name.surname) like :param1 ) ) and ( lower(generatedAlias2.name.motherMaidenName) like :param2 )))]]
(请注意,第137列引用test.project.compensation.model.ClaimantPerson)
我确定这与演员有关。如果我在ClaimantPerson
下有Claimant
字符,我该如何引用CompensationCase
?
以下是类/实体定义的片段:
CompensationCase是我要查询的课程
@Entity
@Table(name = "project_compensation_case")
@EntityListeners({CompensationCaseNumberListener.class})
@JsonIgnoreProperties({"hibernateLazyInitializer", "handler"})
public class CompensationCase extends AutoIdBasedEntity{
@Valid
@NotNull(message = "{compensationCase.claimant.NotNull}")
@OneToOne(cascade = CascadeType.ALL, fetch = FetchType.EAGER, optional = false)
@ForeignKey(name = "FK_CompensationCase_Claimant")
@JoinColumn(name = "claimant_id", unique = true, updatable = false, nullable = false)
private Claimant claimant;
//So on....
}
这是索赔人:
@Entity
@Table(name = "project_compensation_claimant")
@Inheritance(strategy = InheritanceType.JOINED)
@JsonIgnoreProperties({"hibernateLazyInitializer", "handler"})
@JsonTypeInfo(use = JsonTypeInfo.Id.NAME,
include = JsonTypeInfo.As.PROPERTY,
property = "objectType")
@JsonSubTypes({
@JsonSubTypes.Type(ClaimantPerson.class),
@JsonSubTypes.Type(ClaimantOrganization.class)
})
public abstract class Claimant extends AutoIdBasedEntity{
//stuff here
}
这是索赔人员:
@Entity
@Table(name = "project_compensation_claimant_person")
@JsonTypeInfo(use = JsonTypeInfo.Id.NAME,
include = JsonTypeInfo.As.PROPERTY,
property = "objectType")
@JsonIgnoreProperties({"hibernateLazyInitializer", "handler"})
public class ClaimantPerson extends Claimant {
//properties and stuff
}
感谢任何帮助。谢谢!
答案 0 :(得分:0)
原来我不需要.as()
方法。通过做一个子查询,我可以进行伪投射。
所以基本上我的规范的最后一行变成了:
return cb.in(claimantPath).value(claimantPersonSubquery);
这个问题的答案帮助我以正确的方式引导我:Polymorphic JPA query with CriteriaQuery API