SQL語(yǔ)句練習(xí)實(shí)例之一——找出最近的兩次晉升日期與工資額
--程序員們?cè)诰帉懸粋€(gè)雇員報(bào)表,他們需要得到每個(gè)雇員當(dāng)前及歷史工資狀態(tài)的信息,
--以便生成報(bào)表。報(bào)表需要顯示每個(gè)人的晉升日期和工資數(shù)目。
--如果將每條工資信息都放在結(jié)果集的一行中,并讓宿主程序去格式化它。
--應(yīng)用程序的程序員都是一幫懶人,他們需要在每個(gè)雇員的一行上得到當(dāng)前
--和歷史工資信息。這樣就可以寫一個(gè)非常簡(jiǎn)單的循環(huán)語(yǔ)句。
---示例:
create table salaries
( name nvarchar(50) not null,
sal_date date not null,
salary money not null,
)
go
ALTER TABLE [dbo].salaries ADD CONSTRAINT [PK_salaries] PRIMARY KEY CLUSTERED
(
name ,sal_date asc
)WITH (PAD_INDEX = OFF, STATISTICS_NORECOMPUTE = OFF,
SORT_IN_TEMPDB = OFF, IGNORE_DUP_KEY = OFF, ONLINE = OFF, ALLOW_ROW_LOCKS = ON,
ALLOW_PAGE_LOCKS = ON) ON [PRIMARY]
GO
----插入數(shù)據(jù)
insert into salaries
select 'TOM','2010-1-20',2000
union
select 'TOM','2010-6-20',2300
union
select 'TOM','2010-12-20',3000
union
select 'TOM','2011-6-20',4000
union
select 'Dick','2011-6-20',2000
union
select 'Harry','2010-6-20',2000
union
select 'Harry','2011-6-20',2000
go
----方法一、使用left join 連接進(jìn)行查詢(sql 2000及以上版本)
select b.name,b.maxdate,y.salary,b.maxdate2,z.salary
from(select a.name,a.maxdate,MAX(x.sal_date) as maxdate2
from(select w.name,MAX(w.sal_date) as maxdate
from salaries as w
group by w.name) as a
left outer join salaries as x on a.name=x.name and a.maxdate>x.sal_date
group by a.name,a.maxdate) as b
left outer join salaries as y
on b.name=y.name and b.maxdate=y.sal_date
left outer join salaries as z
on b.name=z.name and b.maxdate2=z.sal_date
go
----方法二、這個(gè)方法是對(duì)每個(gè)雇員中的行進(jìn)行編號(hào),然后取出兩個(gè)雇用日期最近的日期,
---(sql 2005以上版本)
select s1.name,
MAX(case when rn=1 then sal_date else null end) as curr_date,
MAX(case when rn=1 then salary else null end) as curr_salary,
MAX(case when rn=2 then sal_date else null end) as prev_date,
MAX(case when rn=2 then salary else null end) as curr_salary
from (select name,sal_date,salary, RANK() over(partition by name order by sal_date desc) rn
from salaries
) s1 where rn<3 group by s1.name
go
---方法三、在sql server 2005之后版本可以使用這種方法 ,使用CTE的方式來實(shí)現(xiàn)
with cte(name,sal_date,sal_amt,rn)
as
(
select name,sal_date,salary,ROW_NUMBER() over(PARTITION by name order by sal_date desc) as rn from salaries
)
select o.name,o.sal_date AS curr_date,o.sal_amt as curr_amt,i.sal_date as prev_date ,i.sal_amt as prev_amt from cte as o
left outer join cte as i on o.name=i.name and i.rn=2 where o.rn=1
go
----方法四、使用視圖,將問題分為兩種情況
---1.只有一次工資變動(dòng)的雇員
---2.有兩次或多次工資變動(dòng)的雇員
create view v_salaries
as
select a.name,a.sal_date,MAX(a.salary) as salary from salaries as a ,salaries as b
where a.sal_date<=b.sal_date and a.name=b.name group by a.name,a.sal_date
having COUNT(*)<=2
go
select a.name,a.sal_date, a.salary,b.sal_date,b.salary from v_salaries a
,v_salaries b
where a.name=b.name and a.sal_date>b.sal_date
union all
select name,max(sal_date),max(salary),cast(null as date),cast(null as decimal(8,2))
from v_salaries
group by name
having count(*)=1
go
drop table salaries
go
drop view v_salaries
相關(guān)文章
SQL SERVER 2014 安裝圖解教程(含SQL SERVER 2014下載)
這篇文章主要介紹了SQL SERVER 2014 安裝圖解教程(含SQL SERVER 2014下載),需要的朋友可以參考下2015-10-10關(guān)于SQL數(shù)據(jù)庫(kù) msdb.dbo.sp_send_dbmail 函數(shù)發(fā)送郵件的場(chǎng)景分析
這篇文章主要介紹了關(guān)于SQL數(shù)據(jù)庫(kù) msdb.dbo.sp_send_dbmail 函數(shù)發(fā)送郵件的場(chǎng)景分析,需要的朋友可以參考下2018-10-10SQL Server SQL高級(jí)查詢語(yǔ)句小結(jié)
高級(jí)查詢?cè)跀?shù)據(jù)庫(kù)中用得是最頻繁的,也是應(yīng)用最廣泛的。 學(xué)習(xí)sqlserver的朋友可以參考下。2011-07-07SQL Server誤區(qū)30日談 第1天 正在運(yùn)行的事務(wù)在服務(wù)器故障轉(zhuǎn)移后繼續(xù)執(zhí)行
每次故障轉(zhuǎn)移都伴隨著某種形式的恢復(fù)。但是如果當(dāng)正在執(zhí)行的事務(wù)沒有Commit時(shí),由于服務(wù)器或?qū)嵗罎?dǎo)致連接斷開,SQL Server可沒有辦法在故障轉(zhuǎn)移后的服務(wù)器重新建立事務(wù)的上下文并繼續(xù)執(zhí)行事務(wù)-無(wú)論你使用的故障轉(zhuǎn)移方式是集群,鏡像,日志傳送或是SAN復(fù)制2013-01-01SqlServer 在事務(wù)中獲得自增ID的實(shí)例代碼
這篇文章主要介紹了 SqlServer 在事務(wù)中獲得自增ID實(shí)例代碼的相關(guān)資料,需要的朋友可以參考下2017-03-03SQL SERVER使用ODBC 驅(qū)動(dòng)建立的鏈接服務(wù)器調(diào)用存儲(chǔ)過程時(shí)參數(shù)不能為NULL值
這篇文章主要介紹了SQL SERVER使用ODBC 驅(qū)動(dòng)建立的鏈接服務(wù)器調(diào)用存儲(chǔ)過程時(shí)參數(shù)不能為NULL值的相關(guān)資料,需要的朋友可以參考下2016-01-01sql server2012附加數(shù)據(jù)庫(kù)問題解決方法
這篇文章主要介紹了sql server2012附加數(shù)據(jù)庫(kù)問題解決方法,需要的朋友可以參考下2014-05-05