NC人员信息维护中任职记录顺序按照日期顺序排序以及处理离职解决方法

48 篇文章 3 订阅

一、NC人员信息维护中任职记录顺序按照日期顺序排序解决方法

--修改任职信息表中的信息(注意,NC65的任职记录表是hi_psnjob)

--备份任职信息表
create table hi_psndoc_deptchg_bak as select * from hi_psndoc_deptchg

--执行如下语句,按照任职开始时间先后顺序将任职记录重新排序
update hi_psndoc_deptchg
   set hi_psndoc_deptchg.recordnum =
       (select a.rank
          from (select pk_psndoc_sub,
                       pk_psnbasdoc,
                       begindate,
                       enddate,
                       cast(row_number()
                       over(partition by pk_psnbasdoc order by begindate desc) as int) - 1 as rank from hi_psndoc_deptchg) a
                 where a.pk_psndoc_sub = hi_psndoc_deptchg.pk_psndoc_sub)


--修改履历信息表中的信息

--备份履历信息表
create table hi_psndoc_work_bak as select * from hi_psndoc_work

--执行如下语句,按照履历开始时间先后顺序将履历记录重新排序
update hi_psndoc_work
   set hi_psndoc_work .recordnum =
       (select a.rank
          from (select pk_psndoc_sub,
                       pk_psnbasdoc,
                       begindate,
                       cast(row_number()
                            over(partition by pk_psnbasdoc order by begindate desc) as int) - 1 as rank from hi_psndoc_work) a 
                where a.pk_psndoc_sub = hi_psndoc_work .pk_psndoc_sub)


--同步任职信息最新一条信息中的职务到工作信息的职务字段

update bd_psndoc set dutyname=(select pk_om_duty from  hi_psndoc_deptchg where hi_psndoc_deptchg.pk_om_duty is not null and recordnum='0' and bd_psndoc.pk_psndoc=hi_psndoc_deptchg.pk_psndoc)

--更新工作信息中职务对应的职务级别和职务分类

--根据工作信息中的职务更新职务级别;
update bd_psndoc set pk_dutyrank=(select dutyrank from om_duty where bd_psndoc.dutyname=om_duty.pk_om_duty);

--根据工作信息中的职务更新职务分类;
update bd_psndoc set series=(select series from om_duty where bd_psndoc.dutyname=om_duty.pk_om_duty);

————————————————

原文链接:https://blog.csdn.net/MJ7128/article/details/84427825
https://www.iteye.com/blog/mj-beijing-1861440

二、nc处理离职的脚本

--查询人员信息(找出人员主键)
 
select pk_psndoc, code, name, pk_hrorg, pk_org from bd_psndoc where name = '潘君一' and code = '01368' and nvl(dr, 0) = 0
 
--查询组织关系(找出组织关系主键)
 
--注意,按问题描述,如果这个人只入职过一次,应该只有一条组织关系记录
 
select pk_psnorg, lastflag, enddate, endflag from hi_psnorg po where pk_psndoc = '0001E11000000003WF3D' 

--将组织关系改为未结束的状态
 
update hi_psnorg set lastflag = 'Y', enddate = null, endflag = 'N' where pk_psnorg = '1001E1100000000WXU8F'
 
 
--查询工作记录信息
 
--注意,按问题描述,应该只有2条组织工作记录(任职记录)
 
select job.pk_psnjob, job.clerkcode from hi_psnjob job where pk_psndoc = '0001E11000000003WF3D'
 
 
--找出工作记录中离职的记录的主键,然后删除工作履历(如果有的话)
 
select pk_psnjob, lastflag, enddate, endflag from hi_psnjob where pk_psndoc = '0001E11000000003WF3D' and enddate is null
 
delete from hi_psndoc_work where pk_psnjob = '工作记录中离职的记录的主键'
 
 
--删除工作记录中离职的记录
 
delete from hi_psnjob where pk_psndoc = '0001E11000000003WF3D' and enddate is null
 
 
--将剩余的那条工作记录改为未结束的状态
 
update hi_psnjob set lastflag = 'Y', enddate = null, endflag = 'N' where pk_psndoc = '0001E11000000003WF3D'
 
 
--例如:
--1、查询人员PK
 
SELECT PK_PSNDOC FROM BD_Psndoc where name='张某某' ----0001A1100000000076JQ
 

--2、根据人员PK在组织关系表,查询结束标识,最新标识,组织PK[0001A1100000000076JP]
 
select * from hi_psnorg where pk_psndoc='0001A1100000000076JQ'
 
select endflag, lastflag from hi_psnorg where pk_psndoc='0001A1100000000076JQ'
 
select endflag, lastflag, pk_psnorg from hi_psnorg where pk_psndoc='0001A1100000000076JQ'
 
--3、更新组织关系表中的结束标识为N
 
--update hi_psnorg
 
update hi_psnorg set endflag='N' where pk_psndoc='0001A1100000000076JQ';
 
select * from hi_psnjob where pk_psnorg
 
select hi_psnjob.pk_psnjob, hi_psnjob.* from hi_psnjob where pk_psnorg='0001A1100000000076JP' --查询误操作的记录pk为1001A11000000002DKA3
 
------------
 
--updatehi_psnorg更新组织关系表中的结束标识为N
 
update hi_psnorg set endflag='N' where pk_psndoc='0001A1100000000076JQ';
 
--delete hi_psnjob 删除那条误操作产生的多余工作记录
 
delete from hi_psnjob where pk_psnjob='1001A11000000002DKA3';
 
 
--update hi_psnjob 更新工作表中的结束标识为N,最终标识为Y,结束日期为空,记录号为第1条【恢复误操作前初始状态】
 
update hi_psnjob set endflag='N', lastflag='Y', enddate=null, recordnum=0 where pk_psnjob='0001A1100000000076JO'; 

————————————————

原文链接:https://wenku.baidu.com/view/9ceca8b487c24028915fc3fd.html

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值