PageRenderTime 44ms CodeModel.GetById 16ms RepoModel.GetById 0ms app.codeStats 0ms

/src/main/java/com/wcs/sys/ejbtimer/service/SysJobLogService.java

https://github.com/YuanZhencai/tms
Java | 237 lines | 169 code | 26 blank | 42 comment | 37 complexity | bc82a12516b87f86884376676c469f8b MD5 | raw file
  1. package com.wcs.sys.ejbtimer.service;
  2. import java.util.ArrayList;
  3. import java.util.Calendar;
  4. import java.util.Date;
  5. import java.util.HashMap;
  6. import java.util.List;
  7. import java.util.Map;
  8. import java.util.Map.Entry;
  9. import java.util.Set;
  10. import javax.ejb.Stateless;
  11. import javax.persistence.EntityManager;
  12. import javax.persistence.PersistenceContext;
  13. import javax.persistence.Query;
  14. import org.primefaces.model.SortOrder;
  15. import org.slf4j.Logger;
  16. import org.slf4j.LoggerFactory;
  17. import com.wcs.base.util.StringUtils;
  18. import com.wcs.sys.ejbtimer.model.SysBusinessLog;
  19. import com.wcs.sys.ejbtimer.model.SysJobLog;
  20. import com.wcs.sys.ejbtimer.vo.SysJobLogVo;
  21. /**
  22. * <p>Project: wcsoa</p>
  23. * <p>Description: </p>
  24. * <p>Copyright © 2013 Wilmar Consultancy Services</p>
  25. * <p>All Rights Reserved.</p>
  26. * @author <a href="mailto:liushengbin@wcs-global.com">Liu Shengbin</a>
  27. */
  28. @Stateless
  29. public class SysJobLogService {
  30. private static final Logger logger = LoggerFactory.getLogger(SysJobLogService.class);
  31. @PersistenceContext(unitName = "pu")
  32. EntityManager em;
  33. /**
  34. *
  35. * <p>Description: 分页查询定时任务日志</p>
  36. * @param first
  37. * @param pageSize
  38. * @param sortField
  39. * @param sortOrder
  40. * @param filters
  41. * @return
  42. */
  43. public Map findAll(int first, int pageSize, String sortField, SortOrder sortOrder, Map<String, String> filters) {
  44. Map map = new HashMap();
  45. StringBuilder strCountSql = new StringBuilder("SELECT count(s.id) FROM SysJobLog s WHERE 1=1 ");
  46. StringBuilder strSql = new StringBuilder("SELECT s FROM SysJobLog s join fetch s.sysJobInfo WHERE 1=1 ");
  47. StringBuilder whereSql = new StringBuilder();
  48. if (filters.get("jobSubject") != null) {
  49. whereSql.append(" AND s.jobSubject LIKE '%" + filters.get("jobSubject") + "%' ");
  50. }
  51. if (filters.get("isSuccess") != null) {
  52. whereSql.append(" AND s.isSuccess =" + filters.get("isSuccess"));
  53. }
  54. strCountSql.append(whereSql);
  55. strSql.append(whereSql);
  56. logger.debug("query sql:" + strSql.toString());
  57. // 得到总记录数
  58. Query countQuery = em.createQuery(strCountSql.toString());
  59. Object countObj = countQuery.getSingleResult();
  60. // 得到查询结果
  61. Query query = em.createQuery(strSql.toString());
  62. query.setFirstResult(first);
  63. query.setMaxResults(pageSize);
  64. List resultList = query.getResultList();
  65. map.put("list", resultList);
  66. map.put("count", ((Long) countObj).intValue());
  67. return map;
  68. }
  69. /**
  70. * 查询任务日志信息
  71. * @param first
  72. * @param pageSize
  73. * @param sortField
  74. * @param sortOrder
  75. * @param queryMap
  76. * @author:LuJiaWei 2013-8-15 下午3:18:21
  77. */
  78. public Map<String, Object> findSysLog(int first, int pageSize, String sortField, SortOrder sortOrder, Map<String, Object> queryMap) {
  79. Map<String, Object> result = new HashMap<String, Object>();
  80. StringBuffer sql = new StringBuffer();
  81. sql.append("select jobLog,info from SysJobLog jobLog left join jobLog.sysJobInfo info ").append("where jobLog.id is not null ");
  82. if (queryMap.size() > 0) {
  83. if (queryMap.get("name") != null && !StringUtils.isBlankOrNull(queryMap.get("name").toString())) {
  84. sql.append("and info.jobSubject like :jobSubject ");
  85. result.put("jobSubject", "%" + queryMap.get("name").toString().trim() + "%");
  86. }
  87. if (queryMap.get("isSuccess") != null && !StringUtils.isBlankOrNull(queryMap.get("isSuccess").toString())) {
  88. String str = queryMap.get("isSuccess").toString();
  89. if ("Y".equals(str)) {
  90. sql.append("and jobLog.isSuccess = true ");
  91. } else if ("N".equals(str)) {
  92. sql.append("and jobLog.isSuccess = false ");
  93. }
  94. }
  95. if(queryMap.get("start") instanceof Date){
  96. sql.append("and jobLog.startTime >= :start ");
  97. result.put("start",queryMap.get("start"));
  98. }
  99. if(queryMap.get("end") instanceof Date){
  100. Calendar instance = Calendar.getInstance();
  101. instance.setTime((Date) queryMap.get("end"));
  102. instance.add(Calendar.DATE, 1);
  103. sql.append("and jobLog.startTime < :end ");
  104. result.put("end",instance.getTime());
  105. }
  106. }
  107. Query countQuery = em.createQuery(sql.toString().replaceFirst("jobLog,info", " count(jobLog.id) "));
  108. if (sortField != null) {
  109. if(SortOrder.ASCENDING.equals(sortOrder)){
  110. sql.append("order by ").append(sortField);
  111. }else{
  112. sql.append("order by ").append(sortField).append(" desc ");
  113. }
  114. } else {
  115. sql.append(" order by jobLog.id desc ");
  116. }
  117. Query createQuery = em.createQuery(sql.toString());
  118. Set<Entry<String, Object>> entrySet = result.entrySet();
  119. for (Entry<String, Object> entry : entrySet) {
  120. countQuery.setParameter(entry.getKey(), entry.getValue());
  121. createQuery.setParameter(entry.getKey(), entry.getValue());
  122. }
  123. int size = Integer.valueOf(countQuery.getSingleResult().toString());
  124. List<SysJobLogVo> sysJobLogVos = new ArrayList<SysJobLogVo>();
  125. if (size > 0) {
  126. List<Object[]> resultList = createQuery.setFirstResult(first).setMaxResults(pageSize).getResultList();
  127. for (Object[] objects : resultList) {
  128. SysJobLogVo sysJobLogVo = new SysJobLogVo(objects[0], objects[1]);
  129. sysJobLogVos.add(sysJobLogVo);
  130. }
  131. }
  132. result.clear();
  133. result.put("size", size);
  134. result.put("result", sysJobLogVos);
  135. return result;
  136. }
  137. /**
  138. * 查看任务详细日志
  139. * @param selectSysJobLogVo
  140. * @author:LuJiaWei 2013-8-15 下午5:35:17
  141. */
  142. public void finLogDetail(SysJobLogVo selectSysJobLogVo) {
  143. if (selectSysJobLogVo != null) {
  144. SysJobLog find = em.find(SysJobLog.class, selectSysJobLogVo.getSysJobLog().getId());
  145. if (find != null){
  146. selectSysJobLogVo.setDetail(find.getLogDetail());
  147. }
  148. }
  149. }
  150. /**
  151. * 查找业务日志
  152. * @param first
  153. * @param pageSize
  154. * @param sortField
  155. * @param sortOrder
  156. * @param filters
  157. * @author:LuJiaWei 2013-8-15 下午6:13:42
  158. */
  159. public Map<String, Object> findSysBusinessLog(int first, int pageSize, String sortField, SortOrder sortOrder, Map<String, String> filters) {
  160. StringBuffer sql = new StringBuffer();
  161. HashMap<String, Object> hashMap = new HashMap<String, Object>();
  162. sql.append("select bg.ID,bg.BUSI_LOG_DESC,bg.BUSI_LOG_INFO,bg.BUSI_LOG_LEVEL,bg.CREATED_DATETIME from SYS_BUSINESS_LOG bg ");
  163. int i = 0;
  164. if (filters.size() > 0) {
  165. if (!StringUtils.isBlankOrNull(filters.get("id"))) {
  166. sql.append("where bg.LOG_ID = " + filters.get("id"));
  167. }
  168. if (!StringUtils.isBlankOrNull(filters.get("BUSI_LOG_DESC"))) {
  169. i++;
  170. sql.append(" and bg.BUSI_LOG_DESC like ?" + i);
  171. hashMap.put(String.valueOf(i), "%" + filters.get("BUSI_LOG_DESC") + "%");
  172. }
  173. if (!StringUtils.isBlankOrNull(filters.get("BUSI_LOG_INFO"))) {
  174. i++;
  175. sql.append(" and bg.BUSI_LOG_INFO like ?" + i);
  176. hashMap.put(String.valueOf(i), "%" + filters.get("BUSI_LOG_INFO") + "%");
  177. }
  178. if (!StringUtils.isBlankOrNull(filters.get("BUSI_LOG_LEVEL"))) {
  179. i++;
  180. sql.append(" and bg.BUSI_LOG_LEVEL like ?" + i);
  181. hashMap.put(String.valueOf(i), "%" + filters.get("BUSI_LOG_LEVEL") + "%");
  182. }
  183. if (!StringUtils.isBlankOrNull(filters.get("CREATED_DATETIME"))) {
  184. i++;
  185. sql.append(" and bg.CREATED_DATETIME like ?" + i);
  186. hashMap.put(String.valueOf(i), "%" + filters.get("CREATED_DATETIME") + "%");
  187. }
  188. }
  189. Query countQuery = em.createNativeQuery(sql.toString().replaceFirst(
  190. "bg.ID,bg.BUSI_LOG_DESC,bg.BUSI_LOG_INFO,bg.BUSI_LOG_LEVEL,bg.CREATED_DATETIME", "count(bg.ID)"));
  191. Query createNativeQuery = em.createNativeQuery(sql.toString(), SysBusinessLog.class);
  192. Set<Entry<String, Object>> entrySet = hashMap.entrySet();
  193. for (Entry<String, Object> entry : entrySet) {
  194. countQuery.setParameter(Integer.valueOf(entry.getKey()), entry.getValue());
  195. createNativeQuery.setParameter(Integer.valueOf(entry.getKey()), entry.getValue());
  196. }
  197. List<SysBusinessLog> sysBusinessLogs = new ArrayList<SysBusinessLog>();
  198. int size = Integer.valueOf(countQuery.getSingleResult().toString());
  199. if (size > 0) {
  200. if (size >= first) {
  201. sysBusinessLogs = createNativeQuery.setFirstResult(first).setMaxResults(pageSize).getResultList();
  202. } else {
  203. sysBusinessLogs = createNativeQuery.setFirstResult(0).setMaxResults(pageSize).getResultList();
  204. }
  205. }
  206. hashMap.clear();
  207. hashMap.put("size", size);
  208. hashMap.put("result", sysBusinessLogs);
  209. return hashMap;
  210. }
  211. }