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