-- ========================================== -- 작업일자: YYYY-MM-DD [쿼리 작성 및 실행 날짜를 기록합니다.] -- 작 성 자: [실행자 이름을 기록합니다.] -- 작업목적: [인건비 일괄 입력된 자료가 중복되거나 잘못 입력된 경우 삭제하고 실행예산 투입실적금액을 변경할 경우 사용합니다.] -- 요청자/티켓번호: [요청 부서 / 요청자 또는 이슈 번호를 기록합니다.] -- 데이타베이스 : MS-SQL -- ========================================== declare @yy char(4), @mm char(2) -- [0] 변경할 데이터 설정 select @yy = '2022', @mm = '10' -- [1] 인건비, 직접경비, 경상비 데이터 검증 (조회) : 중복 여부 미리 확인 권장 select * from GA.dbo.ga_pay where yy = @yy and mm = @mm select * from HPOIMS.dbo.ys_direct_cost where jcost_desc like @yy + '년 '+ @mm + '월%(AUTO)' select * from HPOIMS.dbo.ks_indirect_cost where jcost_desc like @yy + '년 '+ @mm + '월%(AUTO)' -- [2] 인건비/직접경비/경상비 일괄입력된 데이터 삭제(수정/삭제 시 주석 처리 후 공유 권장) /* delete from GA.dbo.ga_pay where yy = @yy and mm = @mm delete from HPOIMS.dbo.ys_direct_cost where jcost_desc like @yy + '년 '+ @mm + '월%(AUTO)' delete from HPOIMS.dbo.ks_indirect_cost where jcost_desc like @yy + '년 '+ @mm + '월%(AUTO)' */ -- [3] 인건비/직접경비/경상비 삭제에 따른 실행예산 투입실적금액 변경(수정/삭제 시 주석 처리 후 공유 권장) /* update HPOIMS.dbo.ys_pbudget set x_amt = (b.soyo_amt+b.input_amt) from HPOIMS.dbo.ys_pbudget a join ( select * from ( select a.pjt_no, a.main, a.sub, a.bud_seq , sum(a.bud_amt) bud_amt , sum(a.bud_x_amt) bud_x_amt , sum(a.bud_e_amt) bud_e_amt , sum(a.soyo_amt) soyo_amt , sum(a.input_amt ) input_amt from ( SELECT pjt_no = a.pjt_no , main = a.main , sub = a.sub , bud_seq = a.bud_seq , closing_yn = ISNULL(a.closing_yn,'N') , bud_amt = ISNULL(a.amt,0) , bud_x_amt = ISNULL(a.x_amt,0) , bud_e_amt = ISNULL(a.e_amt,0) , soyo_amt = 0 , input_amt = 0 FROM HPOIMS.dbo.ys_pbudget a UNION ALL SELECT pjt_no = a.pjt_no , main = a.main , sub = a.sub , bud_seq = a.bud_seq , closing_yn = '' , bud_amt = 0 , bud_x_amt = 0 , bud_e_amt = 0 , soyo_amt = SUM(ISNULL(a.w_amt,0)) , input_amt = 0 FROM HPOIMS.dbo.gm_por_detail a GROUP BY a.pjt_no, a.main, a.sub, a.bud_seq UNION ALL SELECT pjt_no = a.pjt_no , main = a.main , sub = a.sub , bud_seq = a.bud_seq , closing_yn = '' , bud_amt = 0 , bud_x_amt = 0 , bud_e_amt = 0 , soyo_amt = 0 , input_amt = SUM(ISNULL(a.amt,0)) FROM HPOIMS.dbo.ys_direct_cost a GROUP BY a.pjt_no, a.main, a.sub, a.bud_seq ) a GROUP BY a.pjt_no, a.main, a.sub, a.bud_seq ) a where a.bud_x_amt <> (a.soyo_amt+a.input_amt) ) b on a.pjt_no = b.pjt_no and a.main = b.main and a.sub = b.sub and a.bud_seq = b.bud_seq and a.pjt_no like '%' and a.main <> 'AB00' and a.curr = 'WON' and ROUND(isnull(a.x_amt,0)*a.base_rate,0) <> (b.soyo_amt+b.input_amt) update HPOIMS.dbo.ks_budget set budget_use = b.amt from HPOIMS.dbo.ks_budget a join ( select a.* from ( select a.dept_cd, a.year, a.month, a.main_cd, a.sub_cd, isnull(a.budget_use,0) budget_use , isnull(b.amt,0) amt from HPOIMS.dbo.ks_budget a left outer join ( select dept_cd, year, month, main_cd, sub_cd, sum(amt) amt from HPOIMS.dbo.ks_indirect_cost where ctr_yn = 'Y' group by dept_cd, year, month, main_cd, sub_cd ) b on a.dept_cd = b.dept_cd and a.year = b.year and a.month = b.month and a.main_cd = b.main_cd and a.sub_cd = b.sub_cd ) a where a.budget_use <> a.amt ) b on a.dept_cd = b.dept_cd and a.year = b.year and a.month = b.month and a.main_cd = b.main_cd and a.sub_cd = b.sub_cd and a.year >= '2019' */