|
|
@@ -0,0 +1,130 @@
|
|
|
+package com.kingdee.eas.custom.esign.service;
|
|
|
+
|
|
|
+
|
|
|
+import com.kingdee.bos.util.BOSObjectType;
|
|
|
+import com.kingdee.bos.util.BOSUuid;
|
|
|
+
|
|
|
+
|
|
|
+/**
|
|
|
+ * 调薪薪酬取数
|
|
|
+ * @author coyle
|
|
|
+ * 202603
|
|
|
+ */
|
|
|
+public class SalaryAdjustmentDataService extends OtherESignConfigDataService {
|
|
|
+ public String getSql(String id) {
|
|
|
+ StringBuilder sql = new StringBuilder();
|
|
|
+
|
|
|
+
|
|
|
+ // ===================== 薪酬调薪前后对比查询 =====================
|
|
|
+ // 查询内容:员工基础信息 + 固定工资/绩效奖金/福利 调薪前后对比及差额
|
|
|
+ sql.append("SELECT \n");
|
|
|
+
|
|
|
+ // 1. 员工基础信息
|
|
|
+ // 人员姓名
|
|
|
+ sql.append(" person.FNAME_L2 AS person_name, \n");
|
|
|
+ // 入职日期
|
|
|
+ sql.append(" elation.FEnterDate AS entry_date, \n");
|
|
|
+ // 调薪日期(新记录生效日)
|
|
|
+ sql.append(" new_fas.FEffectDay AS salary_adjust_date, \n");
|
|
|
+ sql.append(" firstParty.FName_l2 as firstPartyName , \n");
|
|
|
+ // 2. 固定工资对比(税前:TD01+T012+T013+TD02)
|
|
|
+ // 调薪前固定工资
|
|
|
+ sql.append(" ISNULL(SUM(CASE WHEN sitem_new.FNUMBER IN ('TD01', 'T012', 'T013', 'TD02') THEN old_fas.FMoney ELSE 0 END), 0) AS before_fixed_salary, \n");
|
|
|
+ // 调薪后固定工资
|
|
|
+ sql.append(" ISNULL(SUM(CASE WHEN sitem_new.FNUMBER IN ('TD01', 'T012', 'T013', 'TD02') THEN new_fas.FMoney ELSE 0 END), 0) AS after_fixed_salary, \n");
|
|
|
+ // 固定工资调薪差额
|
|
|
+ sql.append(" ISNULL(SUM(CASE WHEN sitem_new.FNUMBER IN ('TD01', 'T012', 'T013', 'TD02') THEN new_fas.FMoney - old_fas.FMoney ELSE 0 END), 0) AS fixed_salary_diff, \n");
|
|
|
+
|
|
|
+ // 3. 绩效奖金对比(税前:TD04=标准绩效,TD74=试用期绩效)
|
|
|
+ // 3.1 标准绩效奖金
|
|
|
+ // 调薪前标准绩效奖金
|
|
|
+ sql.append(" ISNULL(SUM(CASE WHEN sitem_new.FNUMBER = 'TD04' THEN old_fas.FMoney ELSE 0 END), 0) AS before_perf_bonus, \n");
|
|
|
+ // 调薪后标准绩效奖金
|
|
|
+ sql.append(" ISNULL(SUM(CASE WHEN sitem_new.FNUMBER = 'TD04' THEN new_fas.FMoney ELSE 0 END), 0) AS after_perf_bonus, \n");
|
|
|
+ // 标准绩效奖金差额
|
|
|
+ sql.append(" ISNULL(SUM(CASE WHEN sitem_new.FNUMBER = 'TD04' THEN new_fas.FMoney - old_fas.FMoney ELSE 0 END), 0) AS perf_bonus_diff, \n");
|
|
|
+
|
|
|
+ // 3.2 试用期绩效奖金
|
|
|
+ // 调薪前试用期绩效奖金
|
|
|
+ sql.append(" ISNULL(SUM(CASE WHEN sitem_new.FNUMBER = 'TD74' THEN old_fas.FMoney ELSE 0 END), 0) AS before_prob_perf_bonus, \n");
|
|
|
+ // 调薪后试用期绩效奖金
|
|
|
+ sql.append(" ISNULL(SUM(CASE WHEN sitem_new.FNUMBER = 'TD74' THEN new_fas.FMoney ELSE 0 END), 0) AS after_prob_perf_bonus, \n");
|
|
|
+ // 试用期绩效奖金差额
|
|
|
+ sql.append(" ISNULL(SUM(CASE WHEN sitem_new.FNUMBER = 'TD74' THEN new_fas.FMoney - old_fas.FMoney ELSE 0 END), 0) AS prob_perf_bonus_diff, \n");
|
|
|
+
|
|
|
+ // 4. 福利对比(餐补+艰苦补贴+社保公积金补贴)
|
|
|
+ // 4.1 国内餐补(T014)
|
|
|
+ // 调薪前餐补
|
|
|
+ sql.append(" ISNULL(SUM(CASE WHEN sitem_new.FNUMBER = 'T014' THEN old_fas.FMoney ELSE 0 END), 0) AS before_meal_subsidy, \n");
|
|
|
+ // 调薪后餐补
|
|
|
+ sql.append(" ISNULL(SUM(CASE WHEN sitem_new.FNUMBER = 'T014' THEN new_fas.FMoney ELSE 0 END), 0) AS after_meal_subsidy, \n");
|
|
|
+
|
|
|
+ // 4.2 艰苦补贴(TD05)
|
|
|
+ // 调薪前艰苦补贴
|
|
|
+ sql.append(" ISNULL(SUM(CASE WHEN sitem_new.FNUMBER = 'TD05' THEN old_fas.FMoney ELSE 0 END), 0) AS before_hardship_subsidy, \n");
|
|
|
+ // 调薪后艰苦补贴
|
|
|
+ sql.append(" ISNULL(SUM(CASE WHEN sitem_new.FNUMBER = 'TD05' THEN new_fas.FMoney ELSE 0 END), 0) AS after_hardship_subsidy, \n");
|
|
|
+
|
|
|
+ // 4.3 社保公积金补贴(TD101)
|
|
|
+ // 调薪前社保公积金补贴
|
|
|
+ sql.append(" ISNULL(SUM(CASE WHEN sitem_new.FNUMBER = 'TD101' THEN old_fas.FMoney ELSE 0 END), 0) AS before_social_fund, \n");
|
|
|
+ // 调薪后社保公积金补贴
|
|
|
+ sql.append(" ISNULL(SUM(CASE WHEN sitem_new.FNUMBER = 'TD101' THEN new_fas.FMoney ELSE 0 END), 0) AS after_social_fund \n");
|
|
|
+
|
|
|
+ // ===================== 表关联 =====================
|
|
|
+ // 主表:人员基础信息
|
|
|
+ sql.append("FROM \n");
|
|
|
+ sql.append(" T_bd_Person person \n");
|
|
|
+
|
|
|
+ // 关联:入职日期
|
|
|
+ sql.append("LEFT JOIN \n");
|
|
|
+ sql.append(" T_HR_EmpLaborRelation elation ON person.fid = elation.FPersonID \n");
|
|
|
+
|
|
|
+ // 主表:调薪后记录(当前生效)
|
|
|
+ sql.append("LEFT JOIN \n");
|
|
|
+ sql.append(" T_HR_SFixAdjustSalary new_fas ON person.FID = new_fas.FPersonID \n");
|
|
|
+
|
|
|
+ // 关联:调薪前记录
|
|
|
+ sql.append("LEFT JOIN \n");
|
|
|
+ sql.append(" T_HR_SFixAdjustSalary old_fas ON new_fas.FOldFixAdjustSalaryID = old_fas.FID \n");
|
|
|
+
|
|
|
+ // 关联:薪酬项目字典
|
|
|
+ sql.append("LEFT JOIN \n");
|
|
|
+ sql.append(" T_HR_SCmpItem sitem_new ON new_fas.FCmpItemID = sitem_new.FID \n");
|
|
|
+ sql.append(" LEFT JOIN \n");
|
|
|
+ sql.append(" T_HR_EmployeeContract econtract on econtract.FEmployeeID = person.FID \n");
|
|
|
+ sql.append(" left join T_HR_LabContractFirstParty firstParty on econtract.FContFirstPartyID = firstParty.FID \n");
|
|
|
+
|
|
|
+ // ===================== 查询条件 =====================
|
|
|
+ sql.append("WHERE \n");
|
|
|
+ // 仅保留调薪相关记录
|
|
|
+ sql.append(" new_fas.FAdjustSalaryCauseID IS NOT NULL \n");
|
|
|
+ // 仅保留模板所需薪酬项目
|
|
|
+ sql.append(" AND sitem_new.FNUMBER IN ('TD01', 'T012', 'T013', 'TD02', 'TD04', 'TD74', 'T014', 'TD05', 'TD101') \n");
|
|
|
+ // 调薪后记录为永久有效
|
|
|
+ sql.append(" AND new_fas.FLeffectDay = '2199-12-31 00:00:00' \n");
|
|
|
+
|
|
|
+ BOSUuid read = BOSUuid.read(id);
|
|
|
+ BOSObjectType type = read.getType();
|
|
|
+ if (type.toString().equals("7BD37592")){//id类型为合同
|
|
|
+ sql.append("and person.fid in (select FEmployeeID from T_HR_EmployeeContract where fid = '"+id+"')" ) ;
|
|
|
+ }else if (type.toString().equals("80EF7DED")){//id类型为员工felse
|
|
|
+ sql.append("and person.fid = '"+id+"'");
|
|
|
+ }
|
|
|
+
|
|
|
+ // ===================== 分组 & 排序 =====================
|
|
|
+ // 按员工维度分组,一人一条记录
|
|
|
+ sql.append("GROUP BY \n");
|
|
|
+ sql.append(" person.FID, person.FNAME_L2, elation.FEnterDate, new_fas.FEffectDay , firstParty.FName_l2 \n");
|
|
|
+
|
|
|
+ // -------------------------- ORDER BY子句 --------------------------
|
|
|
+ // 排序规则:按人员姓名升序排列
|
|
|
+ sql.append("ORDER BY \n");
|
|
|
+ sql.append(" person.FNAME_L2");
|
|
|
+
|
|
|
+ System.out.print("osfsql"+sql.toString());
|
|
|
+ return sql.toString();
|
|
|
+ }
|
|
|
+
|
|
|
+
|
|
|
+}
|