Predicate
メソッドは、後でデータベース サービス オブジェクトに渡される のリストを動的に作成しています。述語リストに基づいてテーブル結合を作成するには、各述語の基になる生成クラス Q* を決定する必要があります。getType()
または述語を呼び出すgetClass()
ことは役に立ちません。
これは私が述語を構築する方法です:
Class<?> tableClazz = Class.forName("foo.bar.database.model.Q"+ WordUtils.capitalize(tableName));
Object tableObj = tableClazz.getConstructor(String.class).newInstance(tableName +"1000");
Field colField = tableClazz.getDeclaredField(fieldName);
Object colObj = colField.get(tableObj);
// method name is one of eq, ne, like...
Method m = colObj.getClass().getMethod(methodName, classParam );
return (Predicate) m.invoke(colObj, operand);
クエリ構築コード:
JPAQuery query = new JPAQuery(entityManager);
query = query.from(company);
for(Predicate p : predicates){
// if there's at least one predicat with the underlying db class Foo:
query = query.join(company.foos, new QFoo());
break;
}
List<Object[]> rows = query.where(predicates.toArray(new Predicate[0])).listDistinct(company.id);