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
  • 前言 本文介紹一款使用 C# 與 WPF 開發的音頻播放器,其界面簡潔大方,操作體驗流暢。該播放器支持多種音頻格式(如 MP4、WMA、OGG、FLAC 等),並具備標記、實時歌詞顯示等功能。 另外,還支持換膚及多語言(中英文)切換。核心音頻處理採用 FFmpeg 組件,獲得了廣泛認可,目前 Git ...
  • OAuth2.0授權驗證-gitee授權碼模式 本文主要介紹如何筆者自己是如何使用gitee提供的OAuth2.0協議完成授權驗證並登錄到自己的系統,完整模式如圖 1、創建應用 打開gitee個人中心->第三方應用->創建應用 創建應用後在我的應用界面,查看已創建應用的Client ID和Clien ...
  • 解決了這個問題:《winForm下,fastReport.net 從.net framework 升級到.net5遇到的錯誤“Operation is not supported on this platform.”》 本文內容轉載自:https://www.fcnsoft.com/Home/Sho ...
  • 國內文章 WPF 從裸 Win 32 的 WM_Pointer 消息獲取觸摸點繪製筆跡 https://www.cnblogs.com/lindexi/p/18390983 本文將告訴大家如何在 WPF 裡面,接收裸 Win 32 的 WM_Pointer 消息,從消息裡面獲取觸摸點信息,使用觸摸點 ...
  • 前言 給大家推薦一個專為新零售快消行業打造了一套高效的進銷存管理系統。 系統不僅具備強大的庫存管理功能,還集成了高性能的輕量級 POS 解決方案,確保頁面載入速度極快,提供良好的用戶體驗。 項目介紹 Dorisoy.POS 是一款基於 .NET 7 和 Angular 4 開發的新零售快消進銷存管理 ...
  • ABP CLI常用的代碼分享 一、確保環境配置正確 安裝.NET CLI: ABP CLI是基於.NET Core或.NET 5/6/7等更高版本構建的,因此首先需要在你的開發環境中安裝.NET CLI。這可以通過訪問Microsoft官網下載並安裝相應版本的.NET SDK來實現。 安裝ABP ...
  • 問題 問題是這樣的:第三方的webapi,需要先調用登陸介面獲取Cookie,訪問其它介面時攜帶Cookie信息。 但使用HttpClient類調用登陸介面,返回的Headers中沒有找到Cookie信息。 分析 首先,使用Postman測試該登陸介面,正常返回Cookie信息,說明是HttpCli ...
  • 國內文章 關於.NET在中國為什麼工資低的分析 https://www.cnblogs.com/thinkingmore/p/18406244 .NET在中國開發者的薪資偏低,主要因市場需求、技術棧選擇和企業文化等因素所致。歷史上,.NET曾因微軟的閉源策略發展受限,儘管後來推出了跨平臺的.NET ...
  • 在WPF開發應用中,動畫不僅可以引起用戶的註意與興趣,而且還使軟體更加便於使用。前面幾篇文章講解了畫筆(Brush),形狀(Shape),幾何圖形(Geometry),變換(Transform)等相關內容,今天繼續講解動畫相關內容和知識點,僅供學習分享使用,如有不足之處,還請指正。 ...
  • 什麼是委托? 委托可以說是把一個方法代入另一個方法執行,相當於指向函數的指針;事件就相當於保存委托的數組; 1.實例化委托的方式: 方式1:通過new創建實例: public delegate void ShowDelegate(); 或者 public delegate string ShowDe ...