You cannot select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
weaver-develop/src/weaver/interfaces/shuzhi/cronjob/RelationshipReminderJob.java

140 lines
5.5 KiB
Java

2 years ago
package weaver.interfaces.shuzhi.cronjob;
import com.time.util.DateUtil;
import weaver.conn.RecordSet;
import weaver.general.BaseBean;
import weaver.general.Util;
import weaver.interfaces.schedule.BaseCronJob;
import weaver.interfaces.shuzhi.util.WorkflowUtil;
import java.util.Date;
import java.util.HashMap;
import java.util.Map;
/**
* -
* <p>
* uf_zzjluf_ddjluf_lzblcxbd
* 1
* 2hrmresource
* <p>
* uf_zzjl=zzrq=gdrq
* <p>
* uf_ddjl=ddrq=gdrq
* <p>
* uf_lzblcxbd=jhlzrquf_lzblcxbd_dt1 =gdrq
*
* @author wangj
* @version 1.00
* @Date 2023/7/3
*/
public class RelationshipReminderJob extends BaseCronJob {
@Override
public void execute() {
BaseBean bb = new BaseBean();
String workflowid = bb.getPropValue("relationship", "workflowid");
String id = "";
String lastname = "";
String userid = "";
String sxrq = "";
String gdrq = "";
String date = DateUtil.getCurrentTime("yyyy-MM-dd");
RecordSet rs = new RecordSet();
//转正记录uf_zzjl uf_zzjl生效日期=zzrq转正日期、归档日期=gdrq归档日期
String sql = "select a.id,b.lastname,a.zzry,a.zzrq,a.gdrq from uf_zzjl a left join hrmresource b on a.zzry = b.id where a.txlcid is null";
rs.execute(sql);
while (rs.next()) {
String zt = "";
id = Util.null2String(rs.getString("id"));
lastname = Util.null2String(rs.getString("lastname"));
sxrq = Util.null2String(rs.getString("zzrq"));
gdrq = Util.null2String(rs.getString("gdrq"));
userid = Util.null2String(rs.getString("zzry"));
if ("".equals(id) || "".equals(sxrq) || "".equals(userid)) {
continue;
}
if (sxrq.equals(date)) {
//2、生效日期等于当前日期根据记录数据更新到hrmresource
zt = updateHrmStatus(userid, "1");
}
boolean flag = compareDate(sxrq, date);
if ("".equals(gdrq) && flag) {
//生效日期早于当前日期且无归档日期,生成流程到人员,手动调整;
String requestName = "员工关系更新提醒-" + lastname + "-" + date;
Map<String, String> mainMap = new HashMap<>();
mainMap.put("ygxm", userid);
mainMap.put("gxlx", "0");
mainMap.put("sxrq", sxrq);
// mainMap.put("gdrq",gdrq);
zt = new WorkflowUtil().WorkflowCreateByMainTableMap(userid, workflowid, requestName, "0", mainMap);
if (Util.getIntValue(zt) < 0) {
zt = "";
}
}
}
//员工调动记录uf_ddjl uf_ddjl生效日期=ddrq调动日期、归档日期=gdrq归档日期
// sql = "select a.id,b.sqr,b.lastname,a.ddrq,a.gdrq uf_ddjl a left join hrmresource b on a.sqr = b.id where a.txlcid is null";
// rs.execute(sql);
// while (rs.next()) {
// String zt = "";
// id = Util.null2String(rs.getString("id"));
// lastname = Util.null2String(rs.getString("lastname"));
// sxrq = Util.null2String(rs.getString("ddrq"));
// gdrq = Util.null2String(rs.getString("gdrq"));
// userid = Util.null2String(rs.getString("sqr"));
//
// if ("".equals(id) || "".equals(sxrq) || "".equals(userid)) {
// continue;
// }
//
// if (sxrq.equals(date)) {
// //2、生效日期等于当前日期根据记录数据更新到hrmresource
// zt = updateHrmStatus(userid, "1");
// }
//
// boolean flag = compareDate(sxrq, date);
//
// if ("".equals(gdrq) && flag) {
// //生效日期早于当前日期且无归档日期,生成流程到人员,手动调整;
// String requestName = "员工关系更新提醒-" + lastname + "-" + date;
// Map<String, String> mainMap = new HashMap<>();
// mainMap.put("ygxm", userid);
// mainMap.put("gxlx", "0");
// mainMap.put("sxrq", sxrq);
//// mainMap.put("gdrq",gdrq);
// zt = new WorkflowUtil().WorkflowCreateByMainTableMap(userid, workflowid, requestName, "0", mainMap);
// if (Util.getIntValue(zt) < 0) {
// zt = "";
// }
// }
}
private String updateHrmStatus(String userid, String status) {
RecordSet rs = new RecordSet();
String sql = "update hrmresource set status = '" + status + "' where id = '" + userid + "'";
rs.execute(sql);
return "update";
}
private boolean compareDate(String start, String end) {
boolean flag = false;
Date sdate = DateUtil.parseDate(start, "yyyy-MM-dd");
Date edate = DateUtil.parseDate(end, "yyyy-MM-dd");
if (sdate.getTime() < edate.getTime()) {
flag = true;
}
return flag;
}
}