使用SQL 統計表最大值,最小值,平均值,中位數值

来源:https://www.cnblogs.com/failymao/archive/2023/08/07/17610661.html
-Advertisement-
Play Games

> 問:有一個postgres數據表,表中有update_time, create_time關於時間戳的欄位,選擇某個時間段,計算出update_time減去create_time的值做為耗時時間的欄位duration_time,統計出在這段時間內耗時時間的平均值,中位數值,最大值,和最小值,請問如 ...


問:有一個postgres數據表,表中有update_time, create_time關於時間戳的欄位,選擇某個時間段,計算出update_time減去create_time的值做為耗時時間的欄位duration_time,統計出在這段時間內耗時時間的平均值,中位數值,最大值,和最小值,請問如何通過sql語句實現此統計?

  • 答:您好!您可以使用以下SQL語句來實現您所描述的統計:

    SELECT AVG(duration_time) AS avg_duration, 
           PERCENTILE_CONT(0.5) WITHIN GROUP (ORDER BY duration_time) AS median_duration, 
           MAX(duration_time) AS max_duration, 
           MIN(duration_time) AS min_duration
    FROM (
        SELECT update_time - create_time AS duration_time
        FROM your_table_name
        WHERE update_time BETWEEN start_time AND end_time
    ) subquery;
    

    請註意,您需要將 your_table_name 替換為您的表名,start_timeend_time 替換為您想要查詢的時間段。希望這對您有幫助!

表中還有另一個欄位處置策略欄位為handle_strategy, 按照handle_strategy分組 統計,如何改寫上面的查詢?

  • 您好!如果您想按照 handle_strategy 欄位分組統計,可以使用以下SQL語句:

    SELECT handle_strategy, 
           AVG(duration_time) AS avg_duration, 
           PERCENTILE_CONT(0.5) WITHIN GROUP (ORDER BY duration_time) AS median_duration, 
           MAX(duration_time) AS max_duration, 
           MIN(duration_time) AS min_duration
    FROM (
        SELECT handle_strategy, update_time - create_time AS duration_time
        FROM your_table_name
        WHERE update_time BETWEEN start_time AND end_time
    ) subquery
    GROUP BY handle_strategy;
    

    請註意,您需要將 your_table_name 替換為您的表名,start_timeend_time 替換為您想要查詢的時間段。希望這對您有幫助!

平均數統計保留到整數位,不需要小數; 上面PERCENTILE_CONT(0.5) WITHIN GROUP語句表示的是什麼意思?

  • 您好!如果您想將平均數統計保留到整數位,可以使用 ROUND 函數來實現。以下是修改後的SQL語句:

    SELECT handle_strategy, 
           ROUND(AVG(duration_time)) AS avg_duration, 
           PERCENTILE_CONT(0.5) WITHIN GROUP (ORDER BY duration_time) AS median_duration, 
           MAX(duration_time) AS max_duration, 
           MIN(duration_time) AS min_duration
    FROM (
        SELECT handle_strategy, update_time - create_time AS duration_time
        FROM your_table_name
        WHERE update_time BETWEEN start_time AND end_time
    ) subquery
    GROUP BY handle_strategy;
    

    至於您問的 PERCENTILE_CONT(0.5) WITHIN GROUP (ORDER BY duration_time) 語句,它表示計算 duration_time 欄位的中位數。PERCENTILE_CONT 是一個聚合函數,它用於計算連續分佈的給定百分位數。在這裡,我們使用 0.5 作為參數,表示我們想要計算中位數(即第50百分位數)。WITHIN GROUP (ORDER BY duration_time) 子句用於指定對哪個欄位進行排序以計算百分位數。

    希望這些信息對您有幫助!

♥永遠年輕,永遠熱淚盈眶♥
您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • Debian 沒有像 Ubuntu 提供 Ubuntu-Base 那樣提供打包好的 rootfs, 但是 Debian 提供了一個製作 rootfs 的工具 debootstrap. 以下介紹使用 debootstrap 製作 Debian rootfs 的過程. ...
  • 1.常用命令 pwd 當前路徑 passwd 修改密碼 passwd root 修改root用戶密碼 date 顯示系統日期 sudo + 命令 調用管理許可權 clear 清屏 firefox 瀏覽器打開 shutdown -h now 關閉系統(1) init 0 關閉系統(2) telinit ...
  • 如果把整個Linux操作系統看作層級關係, 根文件系統是位於內核之上的模塊,對於同樣的硬體和架構, Linux各個發行版的區別主要在於根文件系統, 而底層的內核部分幾乎是一樣的. 通過製作根文件系統, 可以更換成其它發行版, 定製自己的最小化安裝. ...
  • GParted-live下載官網:https://gparted.org/download.php 1、用Rufus製作gparted-live啟動盤(Windows) Rufus下載官網:https://rufus.ie 2、 用Unetbootin製作gparted-live啟動盤(Window ...
  • ![](https://img2023.cnblogs.com/blog/3076680/202308/3076680-20230804113710206-1765431897.png) # 1. Any ## 1.1. 任意一個 ## 1.2. 選修了任意一門課程的學生 ### 1.2.1. 找出 ...
  • # mysql備份恢復(mysqldump備份 mysqlbinlog恢復) ## 一、備份的分類 1. 物理備份 ​ 物理備份:對資料庫操作系統的物理文件(如數據文件、日誌文件等) - 冷備份(離線備份) :是在關閉資料庫的時候進行的 - 熱備份(聯機備份) :資料庫處於運行狀態,依賴於資料庫的日 ...
  • 本文分享自華為雲社區《【帶你走進DWS大集群內幕】大集群通信:作業hang、殘留問題定位》,作者: 雨落天穹丶。 前言: 測試過程中,我們會遇到這樣一種情況,我的作業都執行很久了,為啥還不結束,是不是作業hang掉了? 或者說,明明看到CN上的作業都沒了,為什麼通過全局視圖發現DN上還有作業在執行而 ...
  • 基於本次618大促JDV平臺支持大促過程中的表現,共從大促總結、能力沉澱、待提升項3個方向也進行了相應總結和反思。 ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...