sql數(shù)據(jù)庫(kù) sql根據(jù)某一個(gè)字段重復(fù)只取第一條數(shù)據(jù)?
sql根據(jù)某一個(gè)字段重復(fù)只取第一條數(shù)據(jù)?SQLServer,使用row_number配合開(kāi)窗函數(shù),取每條記錄的第一條SELECT*FROM(SELECTCOL1,COL2,ROW_NUMBER()OV
sql根據(jù)某一個(gè)字段重復(fù)只取第一條數(shù)據(jù)?
SQLServer,使用row_number配合開(kāi)窗函數(shù),取每條記錄的第一條
SELECT*FROM(SELECTCOL1,COL2,ROW_NUMBER()OVER(PARTITIONBYCOL1,COL2ORDERBYCOL1,COL2)ASRNKFROMTABLE)AWHERERNK=1
sql根據(jù)某一個(gè)字段重復(fù)只取第一條數(shù)據(jù)?
使用分析函數(shù)row_number() over (partiion by ... order by ...)來(lái)進(jìn)行分組編號(hào),然后取分組標(biāo)號(hào)值為1的記錄即可。目前主流的數(shù)據(jù)庫(kù)都有支持分析函數(shù),很好用。
其中,partition by 是指定按哪些字段進(jìn)行分組,這些字段值相同的記錄將在一起編號(hào);order by則是指定在同一組中進(jìn)行編號(hào)時(shí)是按照怎樣的順序。
示例(SQL Server 2005或以上適用):
select s.* from ( select *, row_number() over (partition by [手機(jī)號(hào)] order by [店鋪]) as group_idx from table_name) swhere s.group_idx = 1
SQL查詢一表所有數(shù)據(jù),有重復(fù)的按時(shí)間取第一條?
select distinct 名稱, 狀態(tài), 時(shí)間 from 表 where 狀態(tài) = 1 order by 時(shí)間 desc 應(yīng)該是樓主想要的~ 有重復(fù)的會(huì)按照時(shí)間取第一條~
oracle表中有很多相同的記錄,怎么只取滿足條件的第一條?
oracle只取滿足條件的n條記錄,和SQL server寫(xiě)法不一樣,要使用關(guān)鍵字rownum。
如果只取1條記錄:select 列名 from 表名 where rownum=1
如果想取前5條記錄:select 列名 from 表名 where rownum>=5