国产xxxx99真实实拍_久久不雅视频_高清韩国a级特黄毛片_嗯老师别我我受不了了小说

資訊專欄INFORMATION COLUMN

用子查詢計算非重復條目,加速五十倍!

nicercode / 810人閱讀

摘要:很有用,但是卻很慢計算非重復的數目是分析的一個災難,顯然,我們要在第一篇博文上討論。在來看一下,圖解可以清楚無誤的表明原因。也許你下次計算非重復結果需要花費一天的時間,試著用子查詢的方法減輕它的負載。

本文說的這個技術是通用的,但為了解釋說明,我們選用了 PostgreSQL。感謝 pgAdminIII 提供的解釋性插圖,這些插圖有很大幫助。

很有用,但是卻很慢

計算非重復的數目是SQL分析的一個災難,顯然,我們要在第一篇博文上討論。

首先一點:我們如果有一個很大的數據集而且可以容忍它不精確。一個像 HyperLogLog 的概率統計器可能是你的首選(我們在以后的博客中會講到HyperLogLog ),但是要追求快速精準的結果,子查詢的方法會節省你很多時間。

讓我們從一個簡單的查詢語句開始吧:哪一個dashboard用戶訪問的最頻繁。

select
  dashboards.name, 
  count(distinct time_on_site_logs.user_id)
from time_on_site_logs 
join dashboards on time_on_site_logs.dashboard_id = dashboards.id
group by name
order by count desc

首先,讓我們假設在user_id 和 dashboard_id上都有高效的索引,并且日志行數要比user_id 和 dashboard_id多很多。

僅僅一千萬行數據,查詢語句就花費了48秒的時間。知道為什么嗎?讓我們看一下明了的圖解吧。

慢的原因是數據庫要遍歷dashboards表和logs表的所有記錄,然后JOIN操作,然后排序,之后才進行實際需要的分組和聚集操作。

先聚集,然后聯合數據表

分組和聚集之后,一切數據庫操作的代價都變小了,因為數據的數量變小了。在分組和聚集的時候,因為我們不需要dashboards.name,所以我們可以在JOIN操作前先進行聚集操作:

select
  dashboards.name,
  log_counts.ct
from dashboards
join (
  select
    dashboard_id,
    count(distinct user_id) as ct
  from time_on_site_logs 
  group by dashboard_id
) as log_counts 
on log_counts.dashboard_id = dashboards.id
order by log_counts.ct desc

語句運行了24秒,獲得了2.4倍的性能提高。在來看一下,圖解可以清楚無誤的表明原因。

像我們預期地那樣,join操作之前先進行了group-and-aggregate操作。快上加快,我們還可以在time_on_site_logs 表上加上索引。

第一步,讓你的數據變小

我們還可以做的更好,我們對日志表做group-and-aggregate操作時,我們處理了一些無關的數據,其實沒有必要。我們可以對每個分組上創建一個哈希集合,這樣,在每個哈希桶中讓每個dashboard_id 挑出那些需要被看到處理的數據。

不用做那么多工作,只用一個哈希集合,我們就可以先去除那些重復的值。然后我們在這個結果上做聚集操作。

select
  dashboards.name,
  log_counts.ct
from dashboards 
join (
  select distinct_logs.dashboard_id, 
  count(1) as ct
  from (
    select distinct dashboard_id, user_id
    from time_on_site_logs
  ) as distinct_logs
  group by distinct_logs.dashboard_id
) as log_counts 
on log_counts.dashboard_id = dashboards.id
order by log_counts.ct desc

我們讓去重和分組聚集一步一步進行,分成兩個階段。首先在(dashboard_id, user_id)對上去重,然后在這基礎上做簡單快速的分組計算工作,JOIN操作還是放在最后。

讓我們來揭曉最終效果:總共花費了0.7秒,是上一次的28倍,最初的68倍。

一般來說,數據大小和數據位置是很重要的,表中的屬性字段的可能取值個數相對很少,所以才有那么明顯的效果,與數據總量相比較,(user_id, dashboard_id) 對的不同值很少。越多的不同的值,各行的數據越分散,所以分組和計算它們花費越長的時間,果然天下沒有白吃的午餐。

也許你下次計算非重復結果需要花費一天的時間,試著用子查詢的方法減輕它的負載。

要問一下,你們是何許人也?

我們做了 Periscope,一個可以使SQL數據分析更快的工具。我們在這里分享一下我們的工具蘊含的算法和技術。你可以到我們的主頁上注冊,從而作為我們的新客戶,我們可以通知你相關事宜。


原文:Use Subqueries to Count Distinct 50X Faster
轉載于:伯樂在線 - sunbiaobiao

文章版權歸作者所有,未經允許請勿轉載,若此文章存在違規行為,您可以聯系管理員刪除。

轉載請注明本文地址:http://m.specialneedsforspecialkids.com/yun/17430.html

相關文章

  • 用子查詢計算重復條目加速十倍

    摘要:很有用,但是卻很慢計算非重復的數目是分析的一個災難,顯然,我們要在第一篇博文上討論。在來看一下,圖解可以清楚無誤的表明原因。也許你下次計算非重復結果需要花費一天的時間,試著用子查詢的方法減輕它的負載。 本文說的這個技術是通用的,但為了解釋說明,我們選用了 PostgreSQL。感謝 pgAdminIII 提供的解釋性插圖,這些插圖有很大幫助。 很有用,但是卻很慢 計算非重復的數目是...

    Pluser 評論0 收藏0

發表評論

0條評論

最新活動
閱讀需要支付1元查看
<