使用Disjunction来做sql中or的配置。
首先看看Disjunction的结构:
public class Disjunction extends Junction {
protected Disjunction() {
super("or");
}
}
public class Junction implements Criterion {
...
}
应用:
String[] diffFlagArray = finder.getDiffFlags().split(",");
Disjunction disjunction = Restrictions.disjunction();
for(String flag : diffFlagArray){
if(flag.equalsIgnoreCase("portName")){
disjunction.add(Restrictions.eq("portNameDiff", '1'));
}else if(flag.equalsIgnoreCase("trustor")){
disjunction.add(Restrictions.eq("trustorDiff", '1'));
}else if(flag.equalsIgnoreCase("trustee")){
disjunction.add(Restrictions.eq("trusteeDiff", '1'));
}else if(flag.equalsIgnoreCase(