国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁(yè) > 數(shù)據(jù)庫(kù) > MySQL > 正文

淺談sql數(shù)據(jù)庫(kù)去重

2020-01-18 23:08:26
字體:
來(lái)源:轉(zhuǎn)載
供稿:網(wǎng)友

  關(guān)于sql去重,我簡(jiǎn)單談一下自己的簡(jiǎn)介,如果各位有建議或有不明白的歡迎多多指出。

  關(guān)于sql去重最常見(jiàn)的有兩種方式:DISTINCT和ROW_NUMBER(),當(dāng)然了ROW_NUMBER()除了去重還有很多其他比較重要的功能,一會(huì)我給大家簡(jiǎn)單說(shuō)說(shuō)我自己在實(shí)際中用到的。

  假如有張UserInfo表,如下圖:

 
   
  現(xiàn)在我們要去掉完全重復(fù)的數(shù)據(jù):SELECT DISTINCT * FROM dbo.UserInfo結(jié)果如下圖:

  

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

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

  

  現(xiàn)在我們已經(jīng)看到,如果不加條件會(huì)把所有數(shù)據(jù)都查出來(lái),所以RowId=1的數(shù)據(jù)就是去重后的數(shù)據(jù);

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

  

  得到了所有的數(shù)據(jù),而且還得到了每條數(shù)據(jù)的行號(hào),其中數(shù)據(jù)的順序可以根據(jù)ORDER BY ID調(diào)節(jié),也就是說(shuō)不去重的話(huà)就不用加PARTITION BY Name了,此功能在分頁(yè)中用的也比較多,假如每頁(yè)15條數(shù)據(jù),分頁(yè)時(shí)直接加條件RowNum Between 1 AND 15就行了。孤狼發(fā)表的博客很少,平時(shí)也比較懶,希望對(duì)大家有用。

發(fā)表評(píng)論 共有條評(píng)論
用戶(hù)名: 密碼:
驗(yàn)證碼: 匿名發(fā)表
主站蜘蛛池模板: 鄂托克前旗| 宣汉县| 沛县| 嫩江县| 曲水县| 体育| 高安市| 固阳县| 囊谦县| 吴江市| 河曲县| 双流县| 平罗县| 华坪县| 汶川县| 武鸣县| 农安县| 克什克腾旗| 集贤县| 太原市| 和静县| 博罗县| 明水县| 南江县| 沁水县| 龙南县| 仁怀市| 扬州市| 巴中市| 娄底市| 沾益县| 旬邑县| 临西县| 贡山| 绥阳县| 青阳县| 观塘区| 南充市| 大安市| 宝应县| 阿巴嘎旗|