mysql學習之基礎篇05

来源:https://www.cnblogs.com/wanghaoyu666/archive/2019/07/31/11274575.html
-Advertisement-
Play Games

mysql中的統計函數: 1. 查詢商品價格中最高的價格: 2. 查詢商品價格中最低的價格: 3. 求庫存總量: 4. 查看所有商品的平均價格: 5. 統計商城內共有多少種商品(不是多少個): count()函數是統計行數值,之所以用count(*)而不用count(列名)是因為如果該列有一行為空, ...


mysql中的統計函數:

1. 查詢商品價格中最高的價格:

select max(shop_price) from goods;

 

2. 查詢商品價格中最低的價格:

select min(shop_price) from goods;

 

3. 求庫存總量:

select sum(goods_number) from goods;

 

 4. 查看所有商品的平均價格:

select avg(shop_price) from goods;

 

5. 統計商城內共有多少種商品(不是多少個):

select count(*) from goods;

count()函數是統計行數值,之所以用count(*)而不用count(列名)是因為如果該列有一行為空,那麼count(列名)不會把它計算在內。

看個小例子:

就算有某一行全是空,用count(*)也能把它計算在內:

 

 統計函數單獨使用意義不大,要和分組配合起來才有用:

mysql 之 group by 分組查詢:

計算一下第三個欄目下所有商品的庫存量之和

select cat_id,sum(goods_number) from goods  where cat_id=3 group by cat_id;

 

 一次計算完每一個欄目下的庫存量之和:

select cat_id,sum(goods_number) from goods  group by cat_id;

嚴格的講,以group by a,b,c為列,select的列只能在a,b,c或者是統計函數中選擇,這樣在語義上才沒有矛盾。

 做個小練習:有以下成績表,求出掛科數等於或高於2門的學生的平均成績:

 

select name,avg(score),sum(score<60)as fail from test5 group by name having fail >=2;

 

排序:order by

取出第四個欄目下的商品,把價格由高到低進行排序:

select *from goods where cat_id=4 order by shop_price desc; #desc 代表降序排列

 

按欄目升序排列,同一個欄目下的商品按價格降序排列

select * from goods order by cat_id asc,shop_price desc;

 

 限制輸出條目limit:

取出商品價格前十的商品:

select goods_id,goods_name,cat_id,shop_price from goods order by shop_price desc limit 10;

最後強調一點:Where,group by,having,order by,limit 五個子句順序不能亂!

 


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 問題:第1天給丈母娘1分錢,第2天給2分錢,第3天給4分錢,以此類推,每天給前一天的2倍,給一個月(按30天)算就行。問:第30天給多少錢,總共給多少錢? 解決方案:1)while迴圈方法(不推薦)一般思維可能就會定義一些變數,然後通過while進行迴圈,腳本會比較繁瑣。這種方法大部分人都能想到,即 ...
  • 存儲過程:對sql的封裝和重用,經編譯創建並保存在資料庫中,通過指定存儲過程的名字並給定參數(需要時)來調用執行。 優缺點: (1) 優點: 執行速度快 存儲過程只在創建時進行編譯,以後每次執行存儲過程都不需要重新編譯,而一般SQL語句沒執行一次就需編譯一次,所以使用存儲過程可提高資料庫的執行速度; ...
  • 從相關度評分和性能表現兩個角度對比 Elasticsearch 中檢索(query)和過濾(filter)的區別: (1) query性能較差, 但支持排序; (2) filter性能優於query, 但不支持按照匹配的相關度進行排序. ...
  • 當前,隨著電商節日的增多(6.18、雙十一、雙十二)、平臺拉新趨於頻繁,大促活動也越來越普遍。作為一個電商平臺,每年都會有一次,甚至幾次的流量“大考”。資料庫作為系統的重要節點,其穩定性和性能格外重要,資料庫的全力保障是一個大的挑戰。電商大促,這場沒有硝煙的戰爭很多人已有體會,在此不再贅述。現在,我 ...
  • 直接上解決方案: 先看一下SQL的 insert 命令吧! a : insert into tablename values (值1,值2,值3,.............) b : insert into tablename (列1,列2,列3,..........) values ( 值1,值2 ...
  • 安裝MySQl8.0.17 下載 MySQL8.0.17 二進位版本 https://dev.mysql.com/downloads/mysql/ 解壓,修改許可權 1 tar xf mysql-8.0.17-linux-glibc2.12-x86_64.tar -C /usr/local/ 2 3 ...
  • 最近用PostgreSql資料庫進行表關聯更新時,發現與之前用的Sql Server 和My Sql語法有很大差別,稍微不註意,很容易出錯。 PostgreSql表更新時,兩個表只允許一個表起別名,一般是被更新的表不起別名,查詢的表起別名 正確的寫法如下 錯誤寫法如下 ...
  • 1.查詢系統使用的是哪一組日誌文件:SELECT * FROM V$LOG; 2.查詢正在使用的組所對應的日誌文件:SELECT * FROM V$LOGFILE; 3.強制日誌切換:ALTER SYSTEM SWITCH LOGFILE; 4.查詢歷史日誌:SELECT * FROM V$LOG_ ...
一周排行
    -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.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...