淺談sql數(shù)據(jù)庫去重
關于sql去重,我簡單談一下自己的簡介,如果各位有建議或有不明白的歡迎多多指出。
關于sql去重最常見的有兩種方式:DISTINCT和ROW_NUMBER(),當然了ROW_NUMBER()除了去重還有很多其他比較重要的功能,一會我給大家簡單說說我自己在實際中用到的。
假如有張UserInfo表,如下圖:
現(xiàn)在我們要去掉完全重復的數(shù)據(jù):SELECT DISTINCT * FROM dbo.UserInfo結果如下圖:
但是現(xiàn)在有個新的需求,要把名字為‘張三'的去重,也就是相同名字的只要一條數(shù)據(jù),要是還用DISTINCT的話就很麻煩了。想必聰明的你已經(jīng)想到此時是ROW_NUMBER()登場的時候了吧。我們只需執(zhí)行這樣一句話就萬事大吉了SELECT * FROM (SELECT ROW_NUMBER() OVER(PARTITION BY Name ORDER BY ID) AS RowId,* FROM dbo.UserInfo) x WHERE x.RowId=1;雖然看起來有點長,但是很容易理解。現(xiàn)在執(zhí)行的結果如下圖:
現(xiàn)在名字重復的數(shù)據(jù)只取了一條,而且是根據(jù)sql語句中的ORDER BY ID取的第一條,其中PARTITION BY后面跟的就是去重的字段,也許你想問為什么要加WHERE x.RowId=1呢,現(xiàn)在我們不加這個條件看看結果如何:SELECT * FROM (SELECT ROW_NUMBER() OVER(PARTITION BY Name ORDER BY ID) AS RowId,* FROM dbo.UserInfo) x,如下圖:
現(xiàn)在我們已經(jīng)看到,如果不加條件會把所有數(shù)據(jù)都查出來,所以RowId=1的數(shù)據(jù)就是去重后的數(shù)據(jù);
ROW_NUMBER()除了可以去重還可以得到表的行號,現(xiàn)在我們只需一下語句:SELECT ROW_NUMBER() OVER(ORDER BY ID) AS RowNum,* FROM dbo.UserInfo,結果如下圖:
得到了所有的數(shù)據(jù),而且還得到了每條數(shù)據(jù)的行號,其中數(shù)據(jù)的順序可以根據(jù)ORDER BY ID調節(jié),也就是說不去重的話就不用加PARTITION BY Name了,此功能在分頁中用的也比較多,假如每頁15條數(shù)據(jù),分頁時直接加條件RowNum Between 1 AND 15就行了。孤狼發(fā)表的博客很少,平時也比較懶,希望對大家有用。
相關文章
mysql 如何使用JSON_EXTRACT() 取json值
這篇文章主要介紹了mysql如何使用JSON_EXTRACT() 取json值的操作方式,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2022-07-07完美解決phpstudy安裝后mysql無法啟動(無需刪除原數(shù)據(jù)庫,無需更改任何配置,無需更改端口)直接共存
這篇文章主要介紹了完美解決phpstudy安裝后mysql無法啟動(無需刪除原數(shù)據(jù)庫,無需更改任何配置,無需更改端口)直接共存 ,需要的朋友可以參考下2019-04-04MySQL Slave 觸發(fā) oom-killer解決方法
這篇文章主要介紹了MySQL Slave 觸發(fā) oom-killer解決方法,需要的朋友可以參考下2016-07-07MySQL中DML添加數(shù)據(jù)insert的操作方法
DML英文全稱Data Manipulation Language數(shù)據(jù)操作語言,用來對數(shù)據(jù)庫中表的數(shù)據(jù)記錄進行增、刪、改在實際開發(fā)過程中使用比較多,務必掌握操作,這篇文章主要介紹了MySQL中DML添加數(shù)據(jù)insert的操作方法,需要的朋友可以參考下2023-07-07