從數(shù)據(jù)庫(kù)中檢索每個(gè)組中的最后記錄-SQLServer 2005/2008我做了一些苦差事,似乎得不到我想要的結(jié)果?;旧希覀?cè)谡麄€(gè)公司都有四個(gè)不同的管理系統(tǒng),我正在定期合并來(lái)自每個(gè)系統(tǒng)的所有數(shù)據(jù)。我的目標(biāo)是每小時(shí)更新數(shù)據(jù)到一個(gè)中央數(shù)據(jù)庫(kù)。下面是我正在使用的一個(gè)示例數(shù)據(jù)集:COMPUTERNAME | SERIALNUMBER | USERNAME | LASTIP | LASTUPDATE | SOURCE
TEST1 | 1111 | BOB | 1.1.1.1 | 1/17/2011 01:00:00 | MGMT_SYSTEM_1
TEST1 | 1111 | BOB | 1.1.1.1 | 1/18/2011 01:00:00 | MGMT_SYSTEM_2
TEST1 | 1111 | PETER | 1.1.1.11 | 1/19/2011 01:00:00 | MGMT_SYSTEM_3
TEST2 | 2222 | GEORGE | 1.1.1.2 | 1/17/2011 01:00:00 | MGMT_SYSTEM_1
TEST3 | 3333 | TOM | 1.1.1.3 | 1/19/2011 01:00:00 | MGMT_SYSTEM_2
TEST4 | 4444 | MIKE | 1.1.1.4 | 1/17/2011 01:00:00 | MGMT_SYSTEM_1
TEST4 | 4444 | MIKE | 1.1.1.41 | 1/19/2011 01:00:00 | MGMT_SYSTEM_3
TEST5 | 5555 | SUSIE | 1.1.1.5 | 1/19/2011 01:00:00 | MGMT_SYSTEM_1因此,我想查詢這個(gè)主表,并且只檢索最新的記錄(基于LASTUPDATE),這樣我就可以獲得關(guān)于該系統(tǒng)的最新信息。問(wèn)題是,每個(gè)數(shù)據(jù)庫(kù)中可能都有一個(gè)系統(tǒng),但它們當(dāng)然永遠(yuǎn)不會(huì)有相同的確切更新時(shí)間。我希望能得到這樣的東西:TEST1 | 1111 | PETER | 1.1.1.11 | 1/19/2011 01:00:00 | MGMT_SYSTEM_3
TEST2 | 2222 | GEORGE | 1.1.1.2 | 1/17/2011 01:00:00 | MGMT_SYSTEM_1
TEST3 | 3333 | TOM | 1.1.1.3 | 1/19/2011 01:00:00 | MGMT_SYSTEM_2
TEST4 | 4444 | MIKE | 1.1.1.41 | 1/19/2011 01:00:00 | MGMT_SYSTEM_3
TEST5 | 5555 | SUSIE | 1.1.1.5 | 1/19/2011 01:00:00 | MGMT_SYSTEM_1我試過(guò)使用MAX函數(shù),但是我只能檢索一個(gè)列。我不能在子查詢中使用這一點(diǎn),因?yàn)槲覜](méi)有一個(gè)唯一的ID字段,可以為我提供最后更新的記錄。其中一個(gè)系統(tǒng)是MySQL數(shù)據(jù)庫(kù),MySQL中的MAX函數(shù)實(shí)際上按照我需要的方式工作,每個(gè)組只返回一條記錄,但它在SQLServer中不起作用。我認(rèn)為我需要使用MAX和左加入,但我的嘗試到目前為止都失敗了。你的幫助將不勝感激。在過(guò)去的3-4個(gè)小時(shí)里,我一直在絞盡腦汁想得到一個(gè)有用的查詢。此主表位于SQLServer 2005服務(wù)器上。謝謝!
3 回答

慕森王
TA貢獻(xiàn)1777條經(jīng)驗(yàn) 獲得超3個(gè)贊
;with cteRowNumber as ( select COMPUTERNAME, SERIALNUMBER, USERNAME, LASTIP, LASTUPDATE, SOURCE, row_number() over(partition by COMPUTERNAME order by LASTUPDATE desc) as RowNum from YourTable)select COMPUTERNAME, SERIALNUMBER, USERNAME, LASTIP, LASTUPDATE, SOURCE from cteRowNumber where RowNum = 1

三國(guó)紛爭(zhēng)
TA貢獻(xiàn)1804條經(jīng)驗(yàn) 獲得超7個(gè)贊
select t.*from twhere t.lastupdate = (select max(t2.lastupdate) from t t2 where t2.computername = t.computername );
(computername, lastupdate)
row_number()
row_number()
添加回答
舉報(bào)
0/150
提交
取消