Mysql中的復(fù)合查詢詳解
1. 基本查詢簡單回顧
條件篩選 | 使用 AND、OR、LIKE 等條件操作符進(jìn)行多條件篩選。 |
排序 | 使用 ORDER BY 對查詢結(jié)果進(jìn)行排序,支持多個字段排序(如按部門號升序,工資降序)。 |
聚合函數(shù)與分組 | 使用 GROUP BY 對數(shù)據(jù)進(jìn)行分組,并使用聚合函數(shù)(如 AVG(), MAX(), COUNT())進(jìn)行匯總。 |
子查詢 | 用于動態(tài)選擇數(shù)據(jù),如查詢工資高于平均工資的員工。 |
內(nèi)嵌查詢 | 查詢工資最高的員工、顯示員工的年薪等。 |
- 查詢工資高于500或崗位為MANAGER的雇員,同時還要滿足他們的姓名首字母為大寫的
select *from emp where ename like 'j%' and (sal>500 or job='MANAGER');
使用年薪進(jìn)行降序排序:
select ename ,job,sal*12+ifnull(comm,0) sarn from emp order by sarn desc;
顯示工資最高的員工的名字和工作崗位:
方案一:
select ename ,job ,sal from emp where sal in(select max(sal) from emp );
方案二:
select ename ,job ,sal from emp order by sal desc limit 1;
顯示工資高于平均工資的員工信息:
select ename ,job ,sal from emp where sal>(select avg(sal) from emp);
顯示每個部門的平均工資和最高工資:
select deptno,format(avg(sal),2),max(sal) from emp group by deptno;
顯示平均工資低于2000的部門號和它的平均工資:
select deptno ,avg(sal) avgsal from emp group by deptno having avgsal<2000;
顯示每種崗位的雇員總數(shù),平均工資:
select job ,count(*) from emp group by job;
2. 多表查詢
聯(lián)接查詢 | 通過表之間的關(guān)系字段(如 deptno)進(jìn)行聯(lián)合查詢,常用的連接方式包括內(nèi)連接(INNER JOIN)等。 |
跨表查詢 | 通過連接多個表(如 EMP 和 DEPT)來獲取聯(lián)合結(jié)果。 |
使用 GROUP BY 和聚合函數(shù) | 計算每個部門的平均工資和最高工資等。 |
連接條件 | 可以通過多個條件進(jìn)行查詢,顯示特定條件下的數(shù)據(jù)。 |
將第一張表的每一條數(shù)據(jù)和第二章表的每一條數(shù)據(jù)相結(jié)合,不加過濾條件得到的結(jié)果被稱為笛卡爾積
笛卡爾積:
顯示部門為10的員工和部門的全部信息
select * from emp,dept where emp.deptno=dept.deptno and emp.deptno=10;
顯示部門為10的員工姓名,部門名和工資
select ename,sal,dname from emp,dept where emp.deptno=dept.deptno and emp.deptno=10;
顯示員工的姓名,工資,及工資級別
select ename ,sal,grade from emp,salgrade where sal between losal and hisal;
3. 自連接(Self-Join)
表的別名 | 自連接時需要使用別名來區(qū)分同一表的不同實(shí)例。 |
示例 | 查找員工的上級(使用 mgr 字段指向經(jīng)理的 empno)。 |
應(yīng)用場景 | 員工與其上級、領(lǐng)導(dǎo)層次的關(guān)系查詢。 |
將兩張相同的表做笛卡爾積
- 顯示員工及員工領(lǐng)導(dǎo)的個人信息
select * from emp e1, emp e2 where e1.empno=e2.mgr;
4. 子查詢
單行子查詢 | 子查詢只返回一行結(jié)果,通常用于 =、< 等條件。 |
多行子查詢 | 子查詢返回多行結(jié)果,常配合 IN、ALL、ANY 等關(guān)鍵字使用。 |
多列子查詢 | 返回多個列的數(shù)據(jù),適用于多條件的篩選。 |
FROM 子查詢 | 將子查詢作為臨時表使用,來簡化復(fù)雜查詢。 |
嵌套查詢 | 通過將查詢嵌套在其他查詢語句中,增加查詢靈活性。 |
4.1單行子查詢
- 顯示SMITH同一部門的員工
select *from emp where deptno =(select deptno from emp where ename='SMITH');
4.2多行子查詢
返回多行記錄的子查詢
in關(guān)鍵字;查詢和10號部門的工作崗位相同的雇員的名字,崗位,工資,部門號,但是不包含10自己的
select ename ,job,sal,deptno from emp where job in(select job from emp where deptno =10)and deptno<>10;
all關(guān)鍵字;顯示工資比部門30的所有員工的工資高的員工的姓名、工資和部門號
select ename,sal,deptno from emp where sal > all(select sal from emp where deptno =30);
any關(guān)鍵字;顯示工資比部門30的任意員工的工資高的員工的姓名、工資和部門號(包含自己部門的員工)
select ename,sal,deptno from emp where sal>any(select sal from emp where deptno=30);
4.3多列子查詢
單行子查詢是指子查詢只返回單列,單行數(shù)據(jù);多行子查詢是指返回單列多行數(shù)據(jù),都是針對單列而言的,而多列子查詢則是指查詢返回多個列數(shù)據(jù)的子查詢語句
查詢和SMITH的部門和崗位完全相同的所有雇員,不含SMITH本人
select * from emp where (deptno,job)=(select deptno,job from emp where ename='SMITH') and ename<>'SMITH';
4.4在from中使用子查詢
在mysql中每一次的查詢結(jié)果都是一個子表。
顯示每個高于自己部門平均工資的員工的姓名、部門、工資、平均工資
select ename,deptno,sal,asal from emp t1,(select deptno dt,avg(sal) asal from emp group by dt)t2 where t1.sal>t2.asal and t1.deptno=t2.dt;
查找每個部門工資最高的人的姓名、工資、部門、最高工資
select ename,sal,emp.deptno,msal from emp ,(select deptno,max(sal)msal from emp group by deptno) emp2 where sal=msal and emp.deptno=emp2.deptno ;
顯示每個部門的信息(部門名,編號,地址)和人員數(shù)量
select *from dept, (select deptno,count(deptno) from emp group by deptno)dept2 where dept.deptno=dept2.deptno;
5. 合并查詢
UNION | 將多個 SELECT 查詢結(jié)果合并,去除重復(fù)記錄。 |
UNION ALL | 將多個 SELECT 查詢結(jié)果合并,不去除重復(fù)記錄。 |
應(yīng)用場景 | 如查詢職位為 MANAGER 或工資高于某數(shù)值的員工。 |
5.1UNION
該操作符用于取得兩個結(jié)果集的并集。當(dāng)使用該操作符時,會自動去掉結(jié)果集中的重復(fù)行。
- 將工資大于2500或職位是MANAGER的人找出來
5.2UNION ALL
該操作符用于取得兩個結(jié)果集的并集。當(dāng)使用該操作符時,不會去掉結(jié)果集中的重復(fù)行。
總結(jié)
以上為個人經(jīng)驗,希望能給大家一個參考,也希望大家多多支持腳本之家。
相關(guān)文章
MySQL中三種關(guān)聯(lián)查詢方式的簡單比較
這篇文章主要介紹了MySQL中三種關(guān)聯(lián)查詢方式的簡單比較,即ON和USING還有傳統(tǒng)的FROM...WHERE...,需要的朋友可以參考下2015-06-06mysql數(shù)據(jù)庫優(yōu)化必會的幾個參數(shù)中文解釋
對于自己配置mysql數(shù)據(jù)庫的朋友,需要注意的幾點(diǎn),下面都是英文的解釋,比較易懂方便和我一樣需要優(yōu)化配置mysql的朋友2008-09-09一文學(xué)習(xí)MySQL?意向共享鎖、意向排他鎖、死鎖
這篇文章主要介紹了MySQL?意向共享鎖、意向排他鎖、死鎖,包括InnoDB表級鎖,意向共享鎖和意向排他鎖及操作方法,本文給大家介紹的非常詳細(xì),需要的朋友可以參考下2022-03-03Mysql從5.6.14安全升級至mysql5.6.25的方法
這篇文章主要介紹了Mysql從5.6.14安全升級至mysql5.6.25的方法,本教程講的非常詳細(xì),具有參考借鑒價值,需要的朋友參考下吧2016-08-08解決Navicat遠(yuǎn)程連接MySQL出現(xiàn) 10060 unknow error的方法
這篇文章主要介紹了解決Navicat遠(yuǎn)程連接MySQL出現(xiàn) 10060 unknow error的方法,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2019-12-12MySQL數(shù)據(jù)庫設(shè)計概念及多表查詢和事物操作
數(shù)據(jù)庫設(shè)計就是根據(jù)業(yè)務(wù)系統(tǒng)具體需求,結(jié)合我們所選用的DBMS,為這個業(yè)務(wù)系統(tǒng)構(gòu)造出最優(yōu)的數(shù)據(jù)存儲模型,本文給大家介紹MySQL數(shù)據(jù)庫設(shè)計概念及多表查詢和事物操作,感興趣的朋友一起看看吧2022-05-05