|  |  |  | 
|---|
|  |  |  | import com.ld.igds.util.ContextUtil; | 
|---|
|  |  |  | import com.ld.igds.util.DateUtil; | 
|---|
|  |  |  | import org.apache.commons.lang3.StringUtils; | 
|---|
|  |  |  | import org.apache.commons.lang3.time.DateFormatUtils; | 
|---|
|  |  |  | import org.hibernate.Session; | 
|---|
|  |  |  | import org.springframework.beans.factory.annotation.Autowired; | 
|---|
|  |  |  | import org.springframework.stereotype.Component; | 
|---|
|  |  |  | 
|---|
|  |  |  | //=====================================库区设备=======================================// | 
|---|
|  |  |  | public void pageData(Page<DeptDevice> page, Map<String, Object> param) | 
|---|
|  |  |  | throws Exception { | 
|---|
|  |  |  | String hql = " from " + DeptDevice.class.getName() + " where companyId=:companyId"; | 
|---|
|  |  |  | String hql = " from " + DeptDevice.class.getName() + " where companyId =:companyId and deptId =:deptId"; | 
|---|
|  |  |  |  | 
|---|
|  |  |  | Map<String, Object> args = new HashMap<>(); | 
|---|
|  |  |  | args.put("companyId", ContextUtil.getCompanyId()); | 
|---|
|  |  |  | args.put("deptId", ContextUtil.subDeptId(null)); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | if (null != param) { | 
|---|
|  |  |  | hql = buildHql(hql, param, args); | 
|---|
|  |  |  | 
|---|
|  |  |  | if (null == data.getCompanyId()) { | 
|---|
|  |  |  | data.setCompanyId(ContextUtil.getCompanyId()); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | if (StringUtils.isEmpty(data.getKqdm())) { | 
|---|
|  |  |  | data.setKqdm(ContextUtil.subDeptId(null)); | 
|---|
|  |  |  | if (StringUtils.isEmpty(data.getDeptId())) { | 
|---|
|  |  |  | data.setDeptId(ContextUtil.subDeptId(null)); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | DefaultDept dept = sysDeptService.getCacheDept(data.getCompanyId(), data.getKqdm()); | 
|---|
|  |  |  | data.setKqmc(dept.getName()); | 
|---|
|  |  |  | data.setUpdateTime(new Date()); | 
|---|
|  |  |  | if (null == data.getId()) { | 
|---|
|  |  |  | data.setId(ContextUtil.getUUID()); | 
|---|
|  |  |  | if (null == data.getSbbh()) { | 
|---|
|  |  |  | data.setSbbh(DateFormatUtils.format(new Date(), "yyyyMMdd") + getIndex(data.getCompanyId())); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | session.saveOrUpdate(data); | 
|---|
|  |  |  | } finally { | 
|---|
|  |  |  | 
|---|
|  |  |  | return null; | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | public String getIndex(String companyId) { | 
|---|
|  |  |  | List<DeptDevice> list = getDataByTime(companyId); | 
|---|
|  |  |  | int index = 10000; | 
|---|
|  |  |  | if (list != null && list.size() > 0) { | 
|---|
|  |  |  | String id = list.get(0).getSbbh().substring(8); | 
|---|
|  |  |  | int temp = Integer.valueOf(id) + 1; | 
|---|
|  |  |  | index += temp; | 
|---|
|  |  |  | }else { | 
|---|
|  |  |  | index ++; | 
|---|
|  |  |  | } | 
|---|
|  |  |  | return String.valueOf(index).substring(1); | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | private List<DeptDevice> getDataByTime(String companyId) { | 
|---|
|  |  |  | String hql = " from " + DeptDevice.class.getName() | 
|---|
|  |  |  | + " where companyId =:companyId "; | 
|---|
|  |  |  |  | 
|---|
|  |  |  | Map<String, Object> args = new HashMap<String, Object>(); | 
|---|
|  |  |  | args.put("companyId", companyId); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | hql += " and updateTime >:startTime"; | 
|---|
|  |  |  | args.put("startTime", DateUtil.getCurZero(new Date())); | 
|---|
|  |  |  |  | 
|---|
|  |  |  |  | 
|---|
|  |  |  | hql += " and updateTime <:endTime"; | 
|---|
|  |  |  | args.put("endTime", DateUtil.getNextZero(new Date())); | 
|---|
|  |  |  |  | 
|---|
|  |  |  |  | 
|---|
|  |  |  | hql += " order by id desc"; | 
|---|
|  |  |  |  | 
|---|
|  |  |  | return this.query(hql, args); | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | public String delData(DeptDevice data) { | 
|---|
|  |  |  | Session session = this.getSessionFactory().openSession(); | 
|---|
|  |  |  | try { | 
|---|
|  |  |  | Map<String, Object> param = new HashMap<>(); | 
|---|
|  |  |  | param.put("code", data.getSbbh()); | 
|---|
|  |  |  | List<DeviceCheckup> list = this.listCheck(param); | 
|---|
|  |  |  | for (DeviceCheckup checkup : list) { | 
|---|
|  |  |  | session.delete(checkup); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | session.delete(data); | 
|---|
|  |  |  | } catch (Exception e) { | 
|---|
|  |  |  | e.printStackTrace(); | 
|---|
|  |  |  | } finally { | 
|---|
|  |  |  | session.flush(); | 
|---|
|  |  |  | session.close(); | 
|---|