JPA 基準クエリの問題に直面しています。if else を使用して条件クエリに複数の where 句を追加するにはどうすればよいですか?
私の要件は次のとおりです。
CriteriaBuilder builder = getEm().getCriteriaBuilder();
CriteriaQuery<Object> query = builder.createQuery(Object.class);
// From
Root<EntityClass> entity= query.from(EntityClass.class);
// Select
query.multiselect(entity.get("id").get("col1"),entity.get("id").get("col2"));
// Where
Predicate p1 = builder.and(builder.equal(entity.get("col3"), value3));
Predicate p2 = builder.and(builder.equal(entity.get("col4"), value4));
Predicate p3 = builder.and(builder.equal(entity.get("col5"), value5));
if(someCondition1){
query.where(p1);
}else if(someCondition2){
query.where(p1);
}
query.where(p3);
上記のコードのステートメント query.where(p3); 以前に設定された where 句の条件 p1 および p2 を置き換えます。私が見つけた代替は、以下のような結合です
if(someCondition1){
query.where(p1, p3);
}else if(someCondition2){
query.where(p2, p3);
}else{
query.where(p3);
}
しかし、これは良いアプローチではありません。なぜなら、if-else がたくさんあると、繰り返しコードを書くのが非常にうまくいかなくなるからです。これに対する解決策はありますか?