2016-07-25 31 views
2

JPA(Hibernate 5.2.1)でJava 8を使用しています。私はlike節を導入して外部キーテーブルの値を使用するまで完全に動作するlike節を持っています。BasicPathUsageException:基本型の属性に結合できません

私は、次のエラーを取得しています:

BasicPathUsageException: Cannot join to attribute of basic type

私はこの問題は、私がテーブルに参加しているという事実に関係していると思うし、私が参加し、テーブルを使用して参加LIKEを作成する方法を確認していません。

従業員 - employee_category - カテゴリ

モデル(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; 

モデル(Category.java):

@Id 
private String id; 

JPA

私が紹介したとき次のコードでは、上記のエラーで失敗します(この問題はこの新しいコード):

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; 
} 

任意の助けが理解されるであろう。

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

これは全体の方法です。

+0

解決済み:参加カテゴリ= from.join( "categories"); – Richard

+0

"解決済み"の場合は、質問に回答者を投稿し、回答に同意します。それから、人々はこの質問に遭遇しないと答えました。 –

答えて

0

解決済み:参加カテゴリ= from.join( "categories");