亚洲精品久久久中文字幕-亚洲精品久久片久久-亚洲精品久久青草-亚洲精品久久婷婷爱久久婷婷-亚洲精品久久午夜香蕉

您的位置:首頁技術文章
文章詳情頁

SQL中去除重復數據的幾種方法匯總(窗口函數對數據去重)

瀏覽:91日期:2023-05-02 10:03:14
目錄
  • 方法1:distinct
  • 方法2:group by
  • 方法3:窗口函數

使用SQL對數據進行提取和分析時,我們經常會遇到數據重復的場景,需要我們對數據進行去重后分析。

以某電商公司的銷售報表為例,常見的去重方法我們用到distinct 或者group by 語句, 今天介紹一種新的方法,利用窗口函數對數據去重。

【字段解釋】

訪客id:進入店鋪瀏覽寶貝的客戶

瀏覽時間:訪客進入店鋪瀏覽頁面的日期

瀏覽時常:訪客進入店鋪瀏覽頁面的時長

現在需要知道店鋪里每個訪客和對應的瀏覽日期(每個訪客同一天瀏覽多次算做一次記錄)

【解題思路】

方法1:distinct

SQL書寫如下:

select distinct 訪客id ,瀏覽時間      from 淘寶日銷售數據表;

查詢結果:

這里用distinct語句多字段進行去重的時候,需要特別注意2點:

1)distinct語法規定對單字段、多字段去重,必須放在第一個查詢字段前。

2)如果對表中多列字段進行去重,去重的過程就是將多字段作為整體去重,比如上面的例子,我們將訪客id和瀏覽時間為整體去去重,而不是對訪客id單獨去重后再對姓名單獨去重,所以會出現相同的訪客id對應不同的瀏覽時間。

方法2:group by

SQL書寫如下:

select 訪客id ,瀏覽時間     from 淘寶日銷售數據表group by 訪客id ,瀏覽時間;

查詢結果:

group by對訪客id 和瀏覽時間進行分組,分組匯總后改變了表的行數,一行只有一個類別,這里使用group by后會將訪客id 和瀏覽時間作為一個類別保留,重復的就會不顯示。

方法3:窗口函數

使用窗口函數進行去重時,比distinct和group by稍微復雜些,窗口函數不會減少原表中的行數,而是對字段進行分組后排序。詳細的窗口函數講解

窗口函數的基本語法如下:

<窗口函數> over (partition by <用于分組的列名>order by <用于排序的列名>)

根據題目要求得出每個訪客和對應的瀏覽日期,我們對訪客id ,瀏覽時間進行分組,對瀏覽時長(秒)進行排序。

SQL書寫如下:

select 訪客id ,瀏覽時間 ,row_number()over(partition by 訪客id ,瀏覽時間order by 瀏覽時長(秒)) as 排名     from 淘寶日銷售數據表;

查詢結果:

窗口函數查詢按照每個客戶和瀏覽日期分組,如果同一天有幾次瀏覽,會根據點贊數排序,篩選排名為1,即可得出每個訪客和對應的瀏覽日期。

SQL書寫如下:

select 訪客id ,瀏覽時間 ,row_number()over(partition by 訪客id ,瀏覽時間order by 瀏覽時長(秒)) as 排名     from 淘寶日銷售數據表;

查詢結果:

去除重復項的三種操作,你get了嗎?歡迎評論區補充你的去重辦法~

到此這篇關于SQL中去除重復數據的幾種方法,我一次性都告你?的文章就介紹到這了,更多相關sql去除重復數據內容請搜索以前的文章或繼續瀏覽下面的相關文章希望大家以后多多支持!

標簽: MsSQL
主站蜘蛛池模板: 99热成人精品国产免男男 | 国产高清视频免费最新在线 | 一级毛片成人免费看a | 鲁丝片一区二区三区免费 | 中文字幕一区日韩在线视频 | 精品视频在线观看你懂的一区 | 欧美日韩中文一区二区三区 | a级毛片无码免费真人 | 国产理论最新国产精品视频 | 国产极品视频 | 污污的视频在线播放 | 亚洲黄色一级毛片 | 欧美伊人激情 | 久久一级视频 | 亚洲综合激情另类专区 | 国精品日韩欧美一区二区三区 | 日韩视频免费一区二区三区 | 国产www色 | 久久国产精品99久久久久久牛牛 | 亚洲国产色婷婷精品综合在线观看 | 亚洲国产日韩在线观看 | 成人午夜精品视频在线观看 | 日本久久久久中文字幕 | 毛片大全网站 | 日韩精品免费看 | 欧美三级视频在线播放 | 日韩人成免费网站大片 | 色网址在线| 91国内精品久久久久怡红院 | 日本高清免费中文字幕不卡 | 免费摸碰碰视频在线观看 | 中文字幕在线观看日韩 | 国产精品一区二区不卡的视频 | 天天亚洲综合 | 蝌蚪久久窝 | 视频一区视频二区在线观看 | 青草青在线免费视频 | 91粉色视频在线观看 | 国产免费黄色网址 | 亚洲欧美日韩一区高清中文字幕 | 亚洲和欧美毛片久久久久 |