JAVA实现按时间段查询数据
html / jsp
<span style="vertical-align: -webkit-baseline-middle;font-size:16px;font-weight:bold;">开始时间:</span> <input name="startTime" id="startTime" type="text" class="Wdate" onfocus="WdatePicker()" style="height: 34px; line-height: 34px; border-radius: 4px; border: 1px solid #ccc; font-size: 14px;"> <span class="ml10 mr8" style="font-size:16px;font-weight:bold;">结束时间: </span> <input name="endTime" id="endTime" type="text" class="Wdate" onfocus="WdatePicker()" style="height: 34px; line-height: 34px; border-radius: 4px; border: 1px solid #ccc; font-size: 14px;"> <input type="submit" class="btn btn-query" id="findTime" value="查询" onClick="toFindTime();" style="float:none;"/>
js方法:
PeoplesafeimgAction.java
/**
* @author lenian 2018 06 12
* 根据时间查询人员画像机务处、运输处、货运处工作量数据并展示
* @param page
* @param startTime
* @param endTime
* @return
*/
public String findPortFolioByTime(){
page.setPageNo(pagenum);
page = (Page<Map<String, Object>>) peopleSafeImgManager.getPortFolioByTime(page, startTime, endTime, deptid, depotid);
JSONArray jsonArray = JSONArray.fromObject(page);
renderTextJSONGBK(jsonArray.toString());
return null;
}
PeopleSafeImgManager.java
/**
* @author lenian 2018 06 12
* 根据时间查询人员画像机务处、运输处、货运处工作量数据并展示
* @param page
* @param startTime
* @param endTime
* @return
*/
@SuppressWarnings("unchecked")
public Page<Map<String, Object>> getPortFolioByTime(Page<Map<String, Object>> page, String startTime, String endTime, Long deptid, Long depotid) {
String depotName = null;
// 判断当站段登录时,传到后台的depotid为空
if (depotid == null) {
Long depot_id = SessionManager.getDepartmentId();
Department department = departmentManager.getObjectById(depot_id);
depotName = department.getName();//站段
} else if (depotid != null && depotid != 0) { // 当处室登录,选择其中某个站段进行了查询
Department department = departmentManager.getObjectById(depotid);
depotName = department.getName();//站段
}
// 根据处室将数据区分开来 lenian 2018 06 25
Department deparent = departmentManager.getObjectById(deptid);
// 当处室登录,并且depotid==0,表示查询所有(注:以上操作可示为参数的准备)
String sql;
if (depotid != null && depotid == 0) {
sql = "select spp.id,
" +
" sei.name,
" +
" spp.id_card,
" +
" to_char(spp.time, yyyy-MM-dd) time,
" +
" spp.ins,
" +
" spp.outs,
" +
" spp.score,
" +
" spp.minute,
" +
" spp.column_number,
" +
" spp.channel_number
" +
" from Security_Portrait_Portfolio spp, Security_Employee_Info sei
" +
" where spp.id_card = sei.idcard_num(+) and sei.office_name = "+ deparent.getName() +"";
} else { // 1、当处室登录,选择其中某个站段进行了查询; 2、站段登录,获取当前站段ID
sql = "select spp.id,
" +
" sei.name,
" +
" spp.id_card,
" +
" to_char(spp.time, yyyy-MM-dd) time,
" +
" spp.ins,
" +
" spp.outs,
" +
" spp.score,
" +
" spp.minute,
" +
" spp.column_number,
" +
" spp.channel_number
" +
" from Security_Portrait_Portfolio spp, Security_Employee_Info sei
" +
" where spp.id_card = sei.idcard_num(+) and spp.depot = "+ depotName +" and sei.office_name = "+ deparent.getName() +"";
}
if (StrUtils.stringQuery(startTime) && StrUtils.stringQuery(endTime)) {
sql += "and to_char(spp.time, yyyy-MM-dd) between "+ startTime +" and "+ endTime +"";
}
sql += "order by spp.create_time desc";
SQLQuery query = dao.getSession().createSQLQuery(sql);
Integer count = Integer.parseInt(dao.getSession()
.createSQLQuery("select count(1) from (" + sql + ")")
.uniqueResult().toString());
if (page.isAutoCount()) {
page.setTotalCount(count);
}
if (page.isFirstSetted()) {
query.setFirstResult(page.getFirst());
}
if (page.isPageSizeSetted()) {
query.setMaxResults(page.getPageSize());
}
query.setResultTransformer(Transformers.ALIAS_TO_ENTITY_MAP);
page.setResult(query.list());
return page;
}
