簡體   English   中英

BasicPathUsageException:無法加入基本類型的屬性

[英]BasicPathUsageException: Cannot join to attribute of basic type

我正在使用Java 8和JPA(Hibernate 5.2.1)。 我有一個完美的like子句,直到我引入like子句來使用外鍵表值。

我收到以下錯誤:

BasicPathUsageException:無法加入基本類型的屬性

我認為這個問題與我有一個連接表的事實有關,我不知道如何使用連接表創建LIKE Join。

員工 - employee_category - 類別

model(Employee.java):

@ManyToMany(cascade = CascadeType.ALL, fetch=FetchType.EAGER)
@JoinTable
(
    name="employee_category",
    joinColumns={ @JoinColumn(name="EMP_ID", referencedColumnName="ID") },
    inverseJoinColumns={ @JoinColumn(name="CAT_ID", referencedColumnName="ID") }
)
private Set<Category> categories;

model(Category.java):

@Id
private String id;

JPA

當我介紹下面的代碼時,它失敗並出現上述錯誤(我認為問題在於這段新代碼):

Join<T, Category> category = from.join("id");
predicates.add(criteriaBuilder.like(category.<String>get("name"), "%" + searchQuery + "%"));

這是整個方法:

protected List<T> findAllCriteria(String[] orderByAsc, String[] orderByDesc, Class<T> typeParameterClass,
        int firstResult, int maxResults, String searchQuery) {
    CriteriaBuilder criteriaBuilder = entityManager.getCriteriaBuilder();
    CriteriaQuery<T> criteriaQuery = criteriaBuilder.createQuery(typeParameterClass);

    // from
    Root<T> from = criteriaQuery.from(typeParameterClass);
    criteriaQuery.select(from);

    // like
    if (searchQuery != null && searchQuery.trim().length() > 0) {

        List<Predicate> predicates = new ArrayList<Predicate>();
        for (String name : getColumnNames(typeParameterClass)) {
            Predicate condition = criteriaBuilder.like(from.<String>get(name), "%" + searchQuery + "%");
            predicates.add(condition);
        }
        Join<T, Category> category = from.join("id");
        predicates.add(criteriaBuilder.like(category.<String>get("name"), "%" + searchQuery + "%"));

        criteriaQuery.where(criteriaBuilder.or(predicates.toArray(new Predicate[] {})));
    }

    List<T> results = (List<T>) entityManager.createQuery(criteriaQuery).setFirstResult(firstResult)
            .setMaxResults(maxResults).getResultList();
    return results;
}

任何幫助將不勝感激。

求助:加入category = from.join(“categories”);

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM