我已经组装了以下类规范:
public ItemVendedorSpecification(String descricao, List<Long> categorias, List<Long> fabricantes, List<Long> vendedores) {
super();
this.descricao = descricao;
this.categorias = categorias;
this.fabricantes = fabricantes;
this.vendedores = vendedores;
}
@Override
public Predicate toPredicate(Root<ItemVendedor> root, CriteriaQuery<?> query, CriteriaBuilder builder) {
if (!descricao.isEmpty()) {
String PalavraChave[] = descricao.split(" ");
for (String filtro : PalavraChave) {
predicates.add(builder.like(builder.upper(root.get("id").get("produto").get("descricaoDetalhada")), "%" + filtro.toUpperCase() + "%"));
}
}
predicates.add(builder.isTrue(root.get("disponivel")));
if(!fabricantes.isEmpty()) {
predicates.add(root.get("id").get("produto").get("fabricante").get("id").in(fabricantes));
}
if(!vendedores.isEmpty()) {
predicates.add(root.get("id").get("vendedor").get("id").in(vendedores));
}
if(!categorias.isEmpty()) {
predicates.add(root.join("id").get("produto").get("categorias").get("id").in(categorias));
}
return builder.and(predicates.toArray(new Predicate[1]));
}
}
除了插入类别标准的谓词外,几乎所有谓词都在起作用。它不起作用,我很难创造它。
它返回以下错误的方式:
"Illegal attempt to dereference path source [null.produto.categorias] of basic type; nested exception is java.lang.IllegalStateException: Illegal attempt to dereference path source [null.produto.categorias] of basic type"
有人可以帮我制作这个吗?
以下是ItemSeller类的详细信息:
public class ItemVendedor implements Serializable{
private static final long serialVersionUID = 1L;
private ItemVendedorPK id = new ItemVendedorPK();
private BigDecimal preco;
private Boolean disponivel;
private Date dt_insert;
private Date dt_update;
private BigDecimal desconto;
public ItemVendedor() {
}
public ItemVendedor(Produto produto, Vendedor vendedor, BigDecimal preco, BigDecimal desconto ,Boolean disponivel) {
super();
this.id.setProduto(produto);
this.id.setVendedor(vendedor);
this.preco = preco;
this.disponivel = disponivel;
this.desconto = desconto;
}
//GETs and SETs
正如您所看到的,它有一个名为id的字段,它是由Vendedor vendedor
和Produto produto
组成的密钥。
在Produto类中,我有一个List Listorias。对于一个产品可以属于几个类别。
反过来,类别类别包含id.
我想在规范中添加一种方法来获取在其分类列表中包含的所有ItemVendedor的某种类别,我将其作为另一个列表列表分类中的参数引用。
答案 0 :(得分:0)
我把它整理好了。我以错误的方式使用查询。以下是解决方案的代码:
$job->despatch_status = $request->get('despatch_status') ?? $job->despatch_status;
这样我们就可以进行验证,以了解产品是否具有参数范围内的某些类别,以实现某些连接。
第一个Join与类代码中的内容相关,这是一个id,ItemSeller表中的这个字段实际上是一个复合键( predicates.add (root.join ("id") join ("product") join ("categories") get ("id") in (categories));
)的类,反过来这个类必须执行连接与产品类,具有类别字段。
因此,我们可以访问每个产品的类别列表,因此如果我们在知情查询参数中包含此列表的任何元素,则购买。