简化了多个if条件语句的判断,使多条件查询的判断更加简单,不用再为条件是否为空而烦恼,这里只是个模版,具体实例还需自己去调解
一:创建List集合,并加载List数据
List listSql = new ArrayList();
String sql ="";
listSql.add("cxUsers");
listSql.add(txtHPHM==null?"":txtHPHM);//判断所得到的内容是否为空,为空将标为空字符,反之得到的是前台页面传过来的值
listSql.add(txthpzl==null?"":txthpzl);
listSql.add(txtWFSJs==null?"":txtWFSJs);
listSql.add(txtWFSwJe==null?"":txtWFSwJe);
listSql.add(zhxxCx==null?"":zhxxCx);//综合信息标记
listSql.add(txtwfdd==null?"":txtwfdd);//违法地点标记
listSql.add(xq==null?"":xq);//辖区标记
listSql.add(txetJdry==null?"":txetJdry);//校对人员标记
sql = this.getZHXXSql(listSql); 二:getZHXXSql方法,用于执行条件sql语句
public String getZHXXSql(List list){// list
StringBuffer sql = new StringBuffer();
if("cxUsers".equals(list.get(0).toString())){
sql.append("select count(*) from nlv_violation t where 1=1 and t.jdzt = '2' and t.jllx='1'");
if(list.size()>1){
if(!"".equals(list.get(1).toString())){//如果不为空则会执行此语句,反之不执行
sql.append(" and t.hphm like '%"+list.get(1).toString()+"%'");
}
}
if(list.size()>2){
if(!"".equals(list.get(2).toString())){
sql.append(" and t.hpzl='"+list.get(2).toString()+"'");
}
}
if(list.size()>3){
if(!"".equals(list.get(3).toString())){
sql.append(" and to_Char(t.wfsj,'yyyy-MM-dd')>='"+list.get(3).toString()+"'");
}
}
if(list.size()>4){
if(!"".equals(list.get(4).toString())){
sql.append(" and to_Char(t.wfsj,'yyyy-MM-dd')<='"+list.get(4).toString()+"'");
}
}
if(list.size()>5){
if(!"".equals(list.get(5).toString())){
sql.append(" and t.sjly='"+list.get(5).toString()+"'");
}
}
if(list.size()>6){
if(!"".equals(list.get(6).toString())){
sql.append(" and t.wfdd like '%"+list.get(6).toString()+"%'");
}
}
if(list.size()>7){
if(!"".equals(list.get(7).toString())){
sql.append(" and t.cjjg='"+list.get(7).toString()+"'");
}
}
if(list.size()>8){
if(!"".equals(list.get(8).toString())){
sql.append(" and t.jdr='"+list.get(8).toString()+"'");
}
}
}
return sql.toString();
}
319

被折叠的 条评论
为什么被折叠?



