( 2010-8-27 記錄)員工薪資歷史 -Union 實現(xiàn): 1、 表結構 Salary ( id , empID , jbxz,yfxz,sfxz,jse , pid ) Perion(id,bm,year,month,sdate,edate) 表結構大體是這樣的,其中 bm 是薪資日期編碼如 2010-8 ,但是不一定也可以是 108 ,無規(guī)則可言。
( 2010-8-27 記錄)員工薪資歷史 -Union 實現(xiàn):
1、 表結構
Salary ( id , empID , jbxz,yfxz,sfxz,jse , pid )
Perion(id,bm,year,month,sdate,edate…)
表結構大體是這樣的,其中 bm 是薪資日期編碼如 2010-8 ,但是不一定也可以是 108 ,無規(guī)則可言。 Year 是薪資年, month 是薪資月, sdate 和 edate 是開始和結束日期。
2. 本來打算用交叉表實現(xiàn)的,原本已經(jīng)用交叉表實現(xiàn)了,不過最后未能用交叉表實現(xiàn)“ xxxx 小計”,只能實現(xiàn)的顯示“小計”,最后改用union 方式實現(xiàn)。
3. 實現(xiàn)要點:
注意 group by 中的字段及順序,注意 order by 中的字段及順序
4 .代碼如下:
/** 統(tǒng)計員工的期間薪資 */ IF EXISTS (select * from sysobjects where id = object_id('sp_count_salary') and OBJECTPROPERTY(id, N'IsProcedure') = 1) DROP PROCEDURE sp_count_salary GO CREATE PROCEDURE sp_count_salary @P_EMP_ID INT, --員工id @P_SPLA_PER_ID INT, --開始期間id @P_EPLA_PER_ID INT --結束期間id WITH encryption AS BEGIN BEGIN TRANSACTION T1 DECLARE @V_S_YEAR INT --開始期間年份 DECLARE @V_S_MONTH INT --開始期間月份 DECLARE @V_E_YEAR INT --結束期間年份 DECLARE @V_E_MONTH INT --結束期間月份 select @V_S_YEAR=pla_per_year,@V_S_MONTH=pla_per_month from pla_period where pla_per_id=@P_SPLA_PER_ID select @V_E_YEAR=pla_per_year,@V_E_MONTH=pla_per_month from pla_period where pla_per_id=@P_EPLA_PER_ID select (CAST(pla_per_year AS NVARCHAR(4)) + '-' + RIGHT('0' + CAST(pla_per_month AS NVARCHAR(2)), 2)) as '時間', sum(pay_res_btax) N'基本薪資',sum(pay_res_atax) N'應發(fā)薪資',sum(pay_res_result) N'實發(fā)薪資',sum(pay_res_tax) N'繳稅額' from pla_period pp,pay_res pr where pp.pla_per_id = pr.pay_res_perid and pay_res_empid = @P_EMP_ID and (pla_per_year > @V_S_YEAR or (pla_per_year = @V_S_YEAR and pla_per_month >= @V_S_MONTH)) and (pla_per_year < @V_E_YEAR or (pla_per_year = @V_E_YEAR and pla_per_month <= @V_E_MONTH)) group by pla_per_year,pla_per_month union ( select cast(pla_per_year as varchar(10))+N'小計' as '時間', sum(pay_res_btax) N'基本薪資',sum(pay_res_atax) N'應發(fā)薪資',sum(pay_res_result) N'實發(fā)薪資',sum(pay_res_tax) N'繳稅額' from pla_period pp,pay_res pr where pp.pla_per_id = pr.pay_res_perid and pay_res_empid = @P_EMP_ID and (pla_per_year > @V_S_YEAR or (pla_per_year = @V_S_YEAR and pla_per_month >= @V_S_MONTH)) and (pla_per_year < @V_E_YEAR or (pla_per_year = @V_E_YEAR and pla_per_month <= @V_E_MONTH)) group by pla_per_year ) union ( select N'合計' as '時間', sum(pay_res_btax) N'基本薪資',sum(pay_res_atax) N'應發(fā)薪資',sum(pay_res_result) N'實發(fā)薪資',sum(pay_res_tax) N'繳稅額' from pla_period pp,pay_res pr where pp.pla_per_id = pr.pay_res_perid and pay_res_empid = @P_EMP_ID and (pla_per_year > @V_S_YEAR or (pla_per_year = @V_S_YEAR and pla_per_month >= @V_S_MONTH)) and (pla_per_year < @V_E_YEAR or (pla_per_year = @V_E_YEAR and pla_per_month <= @V_E_MONTH)) ) order by (CAST(pla_per_year AS NVARCHAR(4)) + '-' + RIGHT('0' + CAST(pla_per_month AS NVARCHAR(2)), 2)) IF @@ERROR > 0 BEGIN ROLLBACK TRANSACTION T1 END ELSE BEGIN COMMIT TRANSACTION T1 END END GO --EXEC sp_count_salary 4901,1131,1153
聲明:本網(wǎng)頁內(nèi)容旨在傳播知識,若有侵權等問題請及時與本網(wǎng)聯(lián)系,我們將在第一時間刪除處理。TEL:177 7030 7066 E-MAIL:11247931@qq.com