本篇文章給大家帶來了關于mysql的相關知識,其中主要介紹了關于子查詢的相關內容,包括了where后面嵌套子查詢、from后面嵌套子查詢、在select后面嵌套子查詢等等內容,下面一起來看一下,希望對大家有幫助。
程序員必備接口測試調試工具:立即使用
Apipost = Postman + Swagger + Mock + Jmeter
Api設計、調試、文檔、自動化測試工具
后端、前端、測試,同時在線協作,內容實時同步
推薦學習:mysql視頻教程
定義:select語句中嵌套select語句,被嵌套的select語句是子查詢。
子查詢可以出現在:
select ....(select).. from ....(select).. where ....(select)..
登錄后復制
1.where后面嵌套子查詢
select * from emp where sal > (select avg(sal) from emp) ;
登錄后復制
2.from后面嵌套子查詢*
SELECT d.dname,AVG(s.grade) '部門平均薪資' FROM emp e JOIN salgrade s ON e.sal BETWEEN s.losal AND s.hisal JOIN dept d ON e.deptno = d.deptno GROUP BY d.dname
登錄后復制
3.在select 后面嵌套子查詢
找出每個員工所在的部門名稱
寫法一:看作臨時表 SELECT t.ename,d.dname FROM dept d JOIN (SELECT e.ename,e.deptno FROM emp e) t ON t.deptno = d.deptno 寫法二:連接查詢 SELECT e.ename,d.dname FROM emp e JOIN dept d ON e.deptno = d.deptno 寫法三:select后嵌套子查詢 SELECT e.ename,(SELECT d.dname FROM dept d WHERE d.deptno = e.deptno) AS dept FROM emp e ;
登錄后復制
4.union
可將查詢結果集相加
SELECT ename,job FROM emp e WHERE job = 'CLERK' UNION SELECT ename,job FROM emp e WHERE job = 'SALESMAN'
登錄后復制
而且兩張不相干的表中數據也能夠因此拼接在一起。(但是列數保持一致)
SELECT ename FROM emp UNION SELECT dname FROM dept
登錄后復制
5.*limit
重點中的重點,分頁查詢全靠它
1)limit是mysql中特有的,其他數據庫中沒有,但是Oracle中有一個相同的機制叫rownum。
2)limit取結果集中的部分數據
3)語法機制:limit startIndex,length
startindex表示起始位置,從0開始,0表示第一條數據。
length表示取幾個。
4)limit是sql語句中最后一個執行的環節。
(當前頁數-1)* 頁的大小 = 當前頁起始下標
推薦學習:mysql視頻教程