程序師世界是廣大編程愛好者互助、分享、學習的平台,程序師世界有你更精彩!
首頁
編程語言
C語言|JAVA編程
Python編程
網頁編程
ASP編程|PHP編程
JSP編程
數據庫知識
MYSQL數據庫|SqlServer數據庫
Oracle數據庫|DB2數據庫
 程式師世界 >> 數據庫知識 >> MYSQL數據庫 >> MySQL綜合教程 >> 淺談sql數據庫去重,淺談sql數據庫

淺談sql數據庫去重,淺談sql數據庫

編輯:MySQL綜合教程

淺談sql數據庫去重,淺談sql數據庫


  關於sql去重,我簡單談一下自己的簡介,如果各位有建議或有不明白的歡迎多多指出。

  關於sql去重最常見的有兩種方式:DISTINCT和ROW_NUMBER(),當然了ROW_NUMBER()除了去重還有很多其他比較重要的功能,一會我給大家簡單說說我自己在實際中用到的。

  假如有張UserInfo表,如下圖:

 
   
  現在我們要去掉完全重復的數據:SELECT DISTINCT * FROM dbo.UserInfo結果如下圖:

  

  但是現在有個新的需求,要把名字為‘張三'的去重,也就是相同名字的只要一條數據,要是還用DISTINCT的話就很麻煩了。想必聰明的你已經想到此時是ROW_NUMBER()登場的時候了吧。我們只需執行這樣一句話就萬事大吉了SELECT * FROM (SELECT ROW_NUMBER() OVER(PARTITION BY Name ORDER BY ID) AS RowId,* FROM dbo.UserInfo) x WHERE x.RowId=1;雖然看起來有點長,但是很容易理解。現在執行的結果如下圖:

  現在名字重復的數據只取了一條,而且是根據sql語句中的ORDER BY ID取的第一條,其中PARTITION BY後面跟的就是去重的字段,也許你想問為什麼要加WHERE x.RowId=1呢,現在我們不加這個條件看看結果如何:SELECT * FROM (SELECT ROW_NUMBER() OVER(PARTITION BY Name ORDER BY ID) AS RowId,* FROM dbo.UserInfo) x,如下圖:

  

  現在我們已經看到,如果不加條件會把所有數據都查出來,所以RowId=1的數據就是去重後的數據;

  ROW_NUMBER()除了可以去重還可以得到表的行號,現在我們只需一下語句:SELECT ROW_NUMBER() OVER(ORDER BY ID) AS RowNum,* FROM dbo.UserInfo,結果如下圖:

  

  得到了所有的數據,而且還得到了每條數據的行號,其中數據的順序可以根據ORDER BY ID調節,也就是說不去重的話就不用加PARTITION BY Name了,此功能在分頁中用的也比較多,假如每頁15條數據,分頁時直接加條件RowNum Between 1 AND 15就行了。孤狼發表的博客很少,平時也比較懶,希望對大家有用。


sql查詢語句,去重、去空字段

Select distinct chnname, pasprt, phone,address
From gstprofile
Where pasprt is not null and len(pasprt)=18 and phone is not null and address is not null
 

SQL語句 去重問題

如果只是連續兩次的話﹐我的辦法是把它插入另外一個表﹐然後ID從2開始﹐再連接查詢
DECLARE @TB1 TABLE(ID INT IDENTITY(1,1),NUM INT)DECLARE @TB2 TABLE(ID INT IDENTITY(2,1),NUM INT)INSERT INTO @TB1 VALUES(111)INSERT INTO @TB1 VALUES(111)INSERT INTO @TB1 VALUES(222)INSERT INTO @TB1 VALUES(222)INSERT INTO @TB1 VALUES(333)INSERT INTO @TB1 VALUES(111)INSERT INTO @TB1 VALUES(111)INSERT INTO @TB2 SELECT NUM FROM @TB1SELECT A.ID,A.NUM FROM @TB1 A LEFT JOIN @TB2 B ON A.ID=B.ID AND A.NUM=B.NUM WHERE B.ID IS NULL效果圖



 

  1. 上一頁:
  2. 下一頁:
Copyright © 程式師世界 All Rights Reserved