先贴代码:
public interface SnippetService {
public int count(Class c,Object[][] eq,Object[][] like,String[][] datetime,
String[] group,String[] asc,String[] desc);
Public List<?> search(Class c,Object[][] eq,Object[][]like,String[][] datetime,
String[] group,String[] asc,String[] desc,
int start, int limit);
}
service接口如上所示,具体参数说明详见上文--SSH动态查询封装接口介绍。
下面介绍serviceImpl:SnippetServiceImpl
@Component("snippetServiceImpl") public class SnippetServiceImpl implements SnippetService { @Resource(name = "snippetDao") private SnippetDao sd ;
public int count(Class c,Object[][] ob,Object[][] like,String[][] datetime, String[] group,String[] asc,String[] desc){ StringBuffer hql = new StringBuffer( "from "+c.getSimpleName()+" j"); String q = sd.getHQL(ob,like,datetime,group,asc,desc); //得到完整hql if (!"".equals(q) && q != null) { hql.append(" where "); hql.append(q); } //参数值集合 Object[] param = sd.getValue(ob,like,datetime).toArray(); return sd.count(hql.toString(), param); } public List<?> search(Class c,Object[][] ob,Object[][] like, String[][] datetime, String[] group,String[] asc,String[] desc, int start, int limit) { StringBuffer hql = new StringBuffer("from "+c.getSimpleName()+" j"); String q = sd.getHQL(ob,like,datetime,group,asc,desc); //得到完整hql if (!"".equals(q) && q != null) { hql.append(" where "); hql.append(q); } //参数值集合 Object[] param = sd.getValue(ob,like,datetime).toArray(); // find方法。根据条件得到记录。start和limit对分页的设置。 return sd.findPublic(hql.toString(), param, start, limit); }
代码备注已介绍的比较清晰,
两方法都调用了Dao层的接口:
public String getHQL(Object[][] ob,Object[][] like,String[][] datetime,
String[] group,String[] asc,String[] desc);
目的是将service拼接的字符串 :"from "+c.getSimpleName()+" j"
同dao层经过判断筛选排序组合得到的后半段hql 相连,得到完整的hql语句。
public List<Object> getValue(Object[][] ob,Object[][] like,String[][] datetime);
目的是对精确、模糊单个或组合查找传入的参数值进行筛选,得到与hql参数相对
应的有效参数集合,其排列顺序不可更改。
count单独调用Dao层的接口:
public int count(String hql, Object[] param);
根据hql及其对应的value在dao层完成查询工作,将总记录数返回。
Search单独调用Dao层的接口:
public List<?> findPublic(String hql, Object[] param,
int start,int limit);
根据hql及其对应的value以及分页value实现数据列表当前页工作。
相关文章:
SSH动态查询封装接口介绍
SSH动态查询具体实现之Dao