mysql中group by,having,order by,limit,distinct的用法和簡單的的多表查詢

来源:https://www.cnblogs.com/cn-zhouchao/archive/2022/07/11/16467528.html
-Advertisement-
Play Games

分組查詢:關鍵字group by的用法 group:組 by:通過 group by :通過....。分組group by列名:通過指定列來分組 一般情況下在題目中出現 "每個" "各個" "不同的" 這一類詞語時基本都會用到group by 分組關鍵字 語法: select 列名 from表名 g ...


分組查詢:關鍵字group by的用法

group:組

by:通過

group by :通過....。分組group by列名:通過指定列來分組

一般情況下在題目中出現 "每個" "各個" "不同的" 這一類詞語時基本都會用到group by 分組關鍵字

語法: select 列名 from表名 group by列名;

多欄位分組語法:select * from 表名 group by 列名1 ,列名2;

分組後的篩選 having的用法

功能:類似於where

註意: 不能代替where,位置不能再group by 前面。且having 後面可以跟列名

也可以跟聚合函數。

語法:select * from 表名 group by 列名 having 條件表達式;

1.查詢各個部門員工平均工資大於2500的員工部門編號;

2.查詢各個部門各個崗位的工資大於1500的員工;

3.查詢部門編號30的各個崗位平均工資;

having 和 where的區別:

1.where 是對分組前的數據進行篩選;

2.having 是對分組後的數據進行篩選;

3.having 後面可以跟列名,函數;

4.where 不能對分組後的數據進行篩選;

5.where 後面不能更函數;

排序關鍵字 order by :

註意:

1.mysql中查詢結果是按升序排序;

2.查詢時排序後如果要求升序或降序那麼,需要將兩種排序的關鍵字補充上;

3.方法一:升序排序關鍵字asc 用法 order by 列名 asc;

4.方法二:降序排序關鍵字desc 用法 order by 列名 desc;

5.多欄位排序:order by 列名1 [asc]desc,列名2[asc] desc ------先按列1排序如果列1值相同則按列2排序;

1.查詢工資大於2000的員工信息按工資降序排序;

select * from emp where sal>2000 order by sal desc;

2.查詢每個崗位平均工資按降序排序;

select job,avg(sal) from emp order by job desc;

3.查詢每個部門平均工資按升序排序;

select deptno ,avg(sal) from emp group by deptno order by deptno desc;

4.查詢部門10的員工信息按工資降序排序;

select * from emp where deptno=10 order by sal desc;

5.查詢工資大於等於3000的員工信息按員工編號降序排序;

select * from emp where sal>=3000 order by empno desc;

6.查詢各個部門的員工的姓名並按部門編號降序排序;

select deptno,ename from emp order by deptno desc;

7.查詢emp表,輸出每個部門的各個職位的平均工資,並按部門編號升序、平均工資降序排序。

select deptno,job,avg(sal) from emp group by deptno,job order by deptno asc,avg(sal) desc;

查詢關鍵字limit的用法

limit一般是用在order by後面

limit又有限制的意思,我們可以抽象的理解為截取

在mysql中的limit m,n意思是從m+1條開始,連續取n條數據

例如: select * from emp order by sal lirmit 0,3;

意思是:查詢emp,表員工所有信息按工資升序排序,只顯工資的1-3位;

1.查詢工資第五高的人信息;

select ename ,sal from emp order by sal desc limit 4,1;

2.查詢工資倒數第三的人信息;

select ename ,sal from emp order by sal asc limit 2,1;

模糊匹配:關鍵字like

like: 像......

模糊匹配支持兩種字元匹配符號

第一種:% 匹配任意個字元;

第二種:_ 匹配一個任意字元;

用法:一般是用在where 條件表達式中;

例如:查詢名字中含R的員工姓名和工資;

select ename ,sal from emp where ename like'%R%';

例如:查詢名字是四個字元的員工姓名和工資;

select ename,sal from emp where ename like"____";

去重: 關鍵字distinct

作用:就是將查詢出來的列值相同的進行去重

例如:查詢有多少個領導;

select count(distinct mgr) from emp;

多表查詢

說明:多表查詢就是根據查詢需要的數據,但是數據部分在不同的表中,查詢的時候需要多個表來獲取數據。

查詢步驟:

第一步:需要先分析即將查詢的數據和給出的條件分別屬於哪些表;
第二步:根據表中的列,來分析表與表之間的聯繫有哪些
直接關係:兩張表之間有相同的列
間接關係:兩張表之間沒有相同的列,但是可以通過其他表建立聯繫;
第三步:mysql語句的編寫
語法:

select 別名1.列名1,別名2.列名2

from 表名1 as 別名1, 表名2 as 別名2

where 別名1.相同列=別名2.相同列

and 其他條件語句;

語句一共有四個部分:

第一部分是確定要查詢顯示的列

第二部分是確定數據來源於哪些表

第三部分是建立兩張表的關係,一般用的是兩張表相同列名的列

第四部分闡述題目中的其他條件

  1. 查詢部門編號10上班的員工姓名,城市,部門編號;

​ select ename,loc,e.deptno

​ from emp e,dept d

​ where e.deptno=d.deptno and e.deptno=10;

  1. 查詢在NEW YORK 上班的員工工號和員工姓名和員工工資和部門名字;
    select e.empno,ename,sal,d.dname -- 查詢的列
    from emp e,dept d -- 查詢的數據源
    where -- 條件關鍵字
    e.deptno=d.deptno -- 建立連接
    and d.loc='NEW YORK'; -- 篩選條件

  2. 查詢芝加哥員工的平均工資
    select d.loc '城市',round(avg(sal),2)'平均工資'
    from emp e,dept d
    where
    e.deptno=d.deptno
    and
    d.loc='CHICAGO';

4.查詢research部門有多少員工;

  1. 第一種方式(不存在重名時可以用這種方法)
    select d.dname '部門',count(e.ename) '員工'
    from emp e,dept d
    where
    e.deptno=d.deptno and d.dname='RESEARCH';

  2. 第二種方式(防止有重名的因素干擾)
    select dname'部門',count(empno)'員工' from emp e ,dept d
    where
    e.deptno=d.deptno and dname='RESEARCH';

  3. 查詢在dallas和new york上班有多少人

select count(empno) -- 查詢的列

from emp e,dept d --查詢的數據來源

where

e.deptno=d.deptno --建立表之間的聯繫

and (loc='DALLAS' or loc='NEW YORK');--題目中的篩選條件

4.查詢sales部門的最低工資的員工姓名和工號

select ename ,empno from emp e,dept d

where e.deptno=d.deptno and dname='SALES' and sal=(select min(sal) from emp e ,dept d where e.deptno=d.deptno and dname='SALES');

select ename ,empno from emp e,dept d

where e.deptno=d.deptno and dname='SALES' order by sal limit 1;

-- 查詢每年要給RESEARCH部門劃多少工資錢

select sum(sal*12) from emp e,dept d

where e.deptno=d.deptno

and dname='RESEARCH';

-- 查詢ACCOUNTING部門員工的平均工資

select d.deptno,avg(sal) from emp e,dept d

where e.deptno=d.deptno

and dname='ACCOUNTING' group by deptno;


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

-Advertisement-
Play Games
更多相關文章
  • yum工具的使用 yum倉庫管理 ###1. yum本地倉庫 掛載鏡像 [root@lnh ~]# cd /etc/yum.repos.d/ [root@lnh yum.repos.d]# ls CentOS-Stream-AppStream.repo CentOS-Stream-RealTime. ...
  • 一 Linux操作系統和Shell 簡介 操作系統(Operating Systems, OS)實際上是一種電腦的軟、硬體資源的進展管理調度的系統級軟體,它的主體是內核(Kernel),其主要負責進程管理、記憶體管理、文件管理和外設管理等功能,而它也向外界提供了內核的介面即系統調用(System C ...
  • 目錄 一、前景回顧 二、實現鍵盤輸入的中斷函數 三、編寫鍵盤驅動 四、實現環形輸入緩衝區 五、運行測試 一、前景回顧 上一回我們完成了鎖的實現,並且利用鎖優化了終端輸出函數。這一回我們來實現鍵盤的輸入,為後面的用戶交互功能打好基礎。 二、實現鍵盤輸入的中斷函數 首先我們需要知道鍵盤是屬於外設,所以對 ...
  • 基礎知識 - 行編輯工具: 一行一行處理文件內容 - 全屏編輯工具:一次性將文件所有內容載入到記憶體中 sed編輯器: Stream Editor 工作原理: 逐行處理文件內容,一次讀取一行內容到模式空間處理。由此反覆,知道最後一行處理完成。 # 處理:可以是輸出到屏幕,也可以是文本的修改替換等操作 ...
  • 鏡像下載、功能變數名稱解析、時間同步請點擊 阿裡雲開源鏡像站 一、Docker鏡像源配置 Docker在安裝後,我們需要前往Docker Hub上拉取(及時就是下載的意思)鏡像。但是,由於網路的原因,我們在Docker Hub上拉取鏡像時網速很慢,這時,我們就需要換Docker的鏡像源,換成我們國內的Doc ...
  • Permute mac是一款非常好用的萬能媒體格式轉換工具,可以幫助用戶轉換自己需要的音頻視頻格式。Permute 3 for mac最新特別版帶給大家!Permute 3 for mac支持當前所有流行的音視頻格式,使用非常方便,Permute 3中文版分享給需要的朋友,趕快試試吧! 詳情:Per ...
  • Downie 4 for Mac(mac最好用的視頻下載軟體) Mac視頻下載軟體哪個好?Downie for Mac 是一款Mac OS平臺上最好用的Mac視頻下載工具,支持1000多個不同的視頻網站,支持國內的優酷、騰訊視頻、bilibili、土豆、愛奇藝、網易、搜狐、微博以及國外的Youtub ...
  • 鏡像下載、功能變數名稱解析、時間同步請點擊 阿裡雲開源鏡像站 一、操作系統 OS(Operating System)既操作系統,是一個包含通用目的或者功能的軟體程式,這些通用目的包含了以下幾項: 硬體驅動 記憶體管理 進程管理 網路管理 安全管理 文件管理 OS主要有三大分類,既伺服器OS、桌面OS以及移動設 ...
一周排行
    -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.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...