GetCompleteSqlService.java 2.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051
  1. package com.kingdee.eas.custom.dataconfig.utils.service;
  2. import com.kingdee.bos.BOSException;
  3. import com.kingdee.bos.Context;
  4. import com.kingdee.bos.bsf.service.app.IHRMsfService;
  5. import com.kingdee.eas.common.EASBizException;
  6. import com.kingdee.eas.custom.dataconfig.utils.SqlUtils;
  7. import com.kingdee.eas.custom.entryconfig.DataConfigFactory;
  8. import com.kingdee.eas.custom.entryconfig.DataConfigInfo;
  9. import com.kingdee.eas.custom.entryconfig.DataConfigSelectFieldEntryCollection;
  10. import com.kingdee.shr.base.syssetting.MSFServiceFacadeFactory;
  11. import java.util.HashMap;
  12. import java.util.Map;
  13. public class GetCompleteSqlService implements IHRMsfService {
  14. @Override
  15. public Object process(Context context, Map map) throws EASBizException, BOSException {
  16. // 从输入参数中获取"number"键对应的值,该值为数据配置的编号
  17. Object o = map.get("number");
  18. Object t = map.get("top");
  19. // 检查number参数是否为空
  20. if (o == null) {
  21. // 若为空则抛出运行时异常,提示number参数不可为空
  22. throw new RuntimeException("number参数不能为空!");
  23. }
  24. // 将number参数转换为字符串类型
  25. String number = o.toString();
  26. // 实例化SQL工具类,用于处理SQL构建相关的工具方法
  27. SqlUtils sqlUtils = new SqlUtils();
  28. // 根据number编号查询对应的数据配置信息
  29. // 此处SQL查询条件为number字段等于输入的编号,查询数据配置主信息及关联的条目信息
  30. DataConfigInfo dataConfigInfo = DataConfigFactory.getLocalInstance(context)
  31. .getDataConfigInfo("select *,SelectFieldEntry.* where number = '" + number + "' order by entrys.seq ");
  32. DataConfigSelectFieldEntryCollection selectFieldEntry = dataConfigInfo.getSelectFieldEntry();
  33. StringBuilder field = new StringBuilder();
  34. if (t!=null){
  35. field.append("top 1").append("\n");
  36. }
  37. StringBuilder selectField = sqlUtils.getSelectField(selectFieldEntry, field);
  38. Map<String,Object> getSqlServiceMap = new HashMap<String,Object>();
  39. getSqlServiceMap.put("number",number);
  40. Object o1 = MSFServiceFacadeFactory.getLocalInstance(context).processService("getSqlService", getSqlServiceMap);
  41. String sql = o1.toString();
  42. sql = sql.replace("{{filed}}",selectField.toString());
  43. return sql.toString();
  44. }
  45. }