Spring Data JPA - 使用规范查询(加入和IN)

时间:2018-05-22 20:36:55

标签: java spring spring-boot spring-data-jpa specification-pattern

我已经组装了以下类规范:

 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 vendedorProduto produto组成的密钥。

在Produto类中,我有一个List Listorias。对于一个产品可以属于几个类别。

反过来,类别类别包含id.

我想在规范中添加一种方法来获取在其分类列表中包含的所有ItemVendedor的某种类别,我将其作为另一个列表列表分类中的参数引用。

1 个答案:

答案 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)); )的类,反过来这个类必须执行连接与产品类,具有类别字段。

因此,我们可以访问每个产品的类别列表,因此如果我们在知情查询参数中包含此列表的任何元素,则购买。