亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

MySQL中sum函數(shù)使用的實例教程

 更新時間:2021年03月17日 16:59:40   作者:A夢多啦A  
這篇文章主要給大家介紹了關(guān)于MySQL中sum函數(shù)使用的相關(guān)資料,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧

文章簡介

今天分享一下MySQL中的sum函數(shù)使用。該函數(shù)已經(jīng)成為大家操作MySQL數(shù)據(jù)庫中時常用到的一個函數(shù),這個函數(shù)統(tǒng)計滿足條件行中指定列的和,想必肯定大家都知道了,本身就沒什么講頭了,這篇文章主要是通過幾個小案例深入了解一下該函數(shù),以及在做MySQL查詢時如何使用sum函數(shù)做優(yōu)化。

語法分析

SUM([DISTINCT] expr) [over_clause]

  • Returns the sum of expr. If the return set has no rows, SUM() returns NULL. The DISTINCT keyword can be used to sum only the distinct values of expr.
  • If there are no matching rows, SUM() returns NULL.
  • This function executes as a window function if over_clause is present.

上面幾句是MySQL官方文檔的一個功能描述。這里翻譯一下大致的意思是什么。

  • 返回expr表達(dá)式的和。如果沒有返回行數(shù),則返回NULL。這里的DISTINCT是為了去掉表達(dá)式expr中的重復(fù)值。
  • 如果沒有匹配到行,該函數(shù)也返回NULL。
  • 如果設(shè)置了over_clause,則該函數(shù)作為窗口函數(shù)執(zhí)行。對窗口函數(shù)不熟悉的,可以去了解一下MySQL中的窗口函數(shù)。

函數(shù)解釋

在使用該函數(shù)時,我們應(yīng)該思考一下,該函數(shù)是如何統(tǒng)計表達(dá)式中的和呢?可能有的程序員會想,這個函數(shù)直接去統(tǒng)計滿足條件中所有行的總和。這么理解其實也沒錯,只是表達(dá)的不是很準(zhǔn)確或者他不夠真實了解運行原理。
實際上該函數(shù)是根據(jù)匹配行的值,一個一個累加起來的。這里舉個例子,在一個訂單表中滿足條件的有10行數(shù)據(jù),我們需要統(tǒng)計訂單中的總價,sum的初始值是0,在匹配到第一行時,訂單價格是10,此時sum就變成10,匹配到第二行,訂單價格是20,這時候sum就是30。第三行訂單價格是50,這時候sum就是80。按照這種方式依次累加。

行數(shù) 訂單價格 sum值
第一行 10.00 10.00
第二行 20.00 30.00
第三行 30.00 60.00
第四行 40.00 100.00
第五行 50.00 150.00
第...行 ... ...
第十行 100.00 550.00

實例演示

假設(shè)有下面一張表(Delivery),表結(jié)構(gòu)如下:

+-----------------------------+---------+
| Column Name   | Type |
+-----------------------------+---------+
| delivery_id   | int |
| customer_id   | int |
| order_date   | date |
| customer_pref_delivery_date | date |
| order_money   | decimal |
+-----------------------------+---------+

delivery_id 是表的主鍵。

該表保存著顧客的食物配送信息,顧客在某個日期下了訂單,并指定了一個期望的配送日期(和下單日期相同或者在那之后)。如果顧客期望的配送日期和下單日期相同,則該訂單稱為 「即時訂單」,否則稱為「計劃訂單」。
里面有如下數(shù)據(jù):

+-------------+-------------+------------+-----------------------------+-------------+
| delivery_id | customer_id | order_date | customer_pref_delivery_date | order_money |
+-------------+-------------+------------+-----------------------------+-------------+
| 1  | 1  | 2019-08-01 | 2019-08-02   | 1.23 |
| 2  | 5  | 2019-08-02 | 2019-08-02   | 1.01 |
| 3  | 1  | 2019-08-11 | 2019-08-11   | 1.09 |
| 4  | 3  | 2019-08-24 | 2019-08-26   | 1.00 |
| 5  | 4  | 2019-08-21 | 2019-08-22   | 10.00 |
| 6  | 2  | 2019-08-11 | 2019-08-13   | 12.09 |
+-------------+-------------+------------+-----------------------------+-------------+

實例一

統(tǒng)計出該表中所有的訂單總金額。這里就很簡單了,也是我們常用的使用方式,直接sum()參數(shù)填寫某一個列就行了。按照上面的語法規(guī)則應(yīng)該是一個表達(dá)式,實際上一列也是一個表達(dá)式。

select sum(order_money) from Delivery;

實例二

寫一條 SQL 查詢語句獲取即時訂單所占的百分比, 保留兩位小數(shù)。這個可能就有一點點難度了,因為你很少用這個語法,如果你用過,就會發(fā)現(xiàn)也很簡單。

首先你要理解,既然是查詢某一個類型的占比,肯定就需要統(tǒng)計總和。我們可以分別去統(tǒng)計到訂單總和sum1,然后再去統(tǒng)計即時訂單總和sum1,然后再去統(tǒng)計即時訂單總和sum1,然后再去統(tǒng)計即時訂單總和sum2。然后在相除就可以了。但是這里明確要求一條SQL語句。那該如何解決呢?

這里就需要你深入了解一下sum的運行原理,我們可以設(shè)想我們一行一行的去讀取數(shù)據(jù),然后讓sum一行一行的累計起來,是不是就可以得到sum2的綜合了?至于sum2的綜合了?至于sum2的綜合了?至于sum1肯定很好統(tǒng)計,直接是表中行數(shù)的綜合。

題解方式一:

select round (
 sum(case when order_date = customer_pref_delivery_date then 1 else 0 end) /
 count(*) * 100,
 2
) as immediate_percentage
from Delivery

題解方式二:

select round (
 sum(order_date = customer_pref_delivery_date) /
 count(*) * 100,
 2
) as immediate_percentage
from Delivery

這里當(dāng)sum表達(dá)式滿足條件,返回1,每次讀到滿足的一行數(shù)據(jù),sum都加1,最后數(shù)據(jù)讀完sum也就加完了。因此滿足條件的總條數(shù)就出來了。

題目來源

改題目來源于LeetCode。

來源:力扣(LeetCode)

鏈接:leetcode-cn.com/problems/im

還有一個比較不錯的例子,推薦好好解讀一下。加深該函數(shù)的使用場景。

http://chabaoo.cn/article/207813.htm

總結(jié)

到此這篇關(guān)于MySQL中sum函數(shù)使用的文章就介紹到這了,更多相關(guān)MySQL sum函數(shù)使用內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • 淺析MySQL 主鍵使用數(shù)字還是uuid查詢快

    淺析MySQL 主鍵使用數(shù)字還是uuid查詢快

    在實際開發(fā)中可能會生成uuid作為主鍵那么疑問來了,到底MySQL 主鍵使用數(shù)字還是uuid查詢快呢?下面小編給大家?guī)韺嵗a給大家詳細(xì)介紹,感興趣的朋友跟隨小編一起看看吧
    2021-08-08
  • Linux系統(tǒng)中安裝MySQL的詳細(xì)圖文步驟

    Linux系統(tǒng)中安裝MySQL的詳細(xì)圖文步驟

    本文的主要內(nèi)容是在 Linux 上安裝 MySQL,以下內(nèi)容是源于 B站 - MySQL數(shù)據(jù)庫入門到精通 整理而來,需要的朋友可以參考下
    2023-06-06
  • mysql?分組函數(shù)和分組查詢使用詳解

    mysql?分組函數(shù)和分組查詢使用詳解

    分組函數(shù)用作統(tǒng)計使用,又稱聚合函數(shù),統(tǒng)計函數(shù),組函數(shù),這篇文章主要介紹了mysql分組函數(shù)分組查詢的操作代碼,本文給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2024-01-01
  • mysql中插入emoji表情失敗的原因與解決

    mysql中插入emoji表情失敗的原因與解決

    這篇文章主要給大家介紹了關(guān)于mysql中插入emoji表情失敗的原因與解決方法,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2018-12-12
  • mysql 8.0.12 快速安裝教程

    mysql 8.0.12 快速安裝教程

    這篇文章主要為大家詳細(xì)介紹了mysql 8.0.12的快速安裝教程,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2018-08-08
  • MySQL線程處于Opening tables的問題解決方法

    MySQL線程處于Opening tables的問題解決方法

    在本篇文章里小編給大家分享了關(guān)于MySQL線程處于Opening tables的問題解決方法,有興趣的朋友們學(xué)習(xí)下。
    2019-01-01
  • Mysql 忘記root密碼的完美解決方法

    Mysql 忘記root密碼的完美解決方法

    通常在使用Mysql數(shù)據(jù)庫時,如果長時間沒有登陸,或者由于工作交接完成度不高,會導(dǎo)致數(shù)據(jù)庫root登陸密碼忘記,本文給大家介紹一種當(dāng)忘記mysql root密碼時的解決辦法,一起看看吧
    2016-12-12
  • 通過案例分析MySQL中令人頭疼的Aborted告警

    通過案例分析MySQL中令人頭疼的Aborted告警

    這篇文章通過案例跟大家分析了MySQL中令人頭疼的Aborted告警的相關(guān)資料,文中將Aborted告警介紹的非常詳細(xì),對大家具有一定的參考學(xué)習(xí)價值,需要的朋友們下面來一起看看吧。
    2017-06-06
  • Mysql出現(xiàn)問題:error?while?loading?shared?libraries:?libaio解決方案

    Mysql出現(xiàn)問題:error?while?loading?shared?libraries:?libaio解

    這篇文章主要介紹了Mysql出現(xiàn)問題:error?while?loading?shared?libraries:?libaio解決方案的相關(guān)資料,需要的朋友可以參考下
    2022-10-10
  • MySQL中CONCAT()函數(shù)拼接出現(xiàn)NULL的問題解決

    MySQL中CONCAT()函數(shù)拼接出現(xiàn)NULL的問題解決

    本文主要介紹了MySQL中CONCAT()函數(shù)拼接出現(xiàn)NULL的問題解決,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2023-03-03

最新評論