【MySQL】復合查詢(重點)-- 詳解

?一、基本查詢練習回顧

1、查詢工資高于?500?或崗位為?MANAGER?的雇員,同時還要滿足他們的姓名首字母為大寫的?J


2、按照部門號升序而雇員的工資降序排序


3、使用年薪進行降序排序


4、顯示工資最高的員工的名字和工作崗位


5、顯示工資高于平均工資的員工信息


6、顯示每個部門的平均工資和最高工資


7、顯示平均工資低于2000的部門號和它的平均工資


8、顯示每種崗位的雇員總數,平均工資


二、多表查詢

實際開發中往往數據來自不同的表,所以需要多表查詢。這里我們用一個簡單的公司管理系統,有三張表 emp,dept,salgrade 來演示如何進行多表查詢。

?練習
1、顯示雇員名、雇員工資以及所在部門的名字因為上面的數據來自?emp?和 dept?表,因此要聯合查詢(將數據進行窮舉組合 —— 笛卡爾積)

其實我們只要?emp?表中的?deptno=dept?表中的?deptno?字段的記錄:


2、顯示部門號為?10 的部門名,員工名和工資


3、顯示各個員工的姓名,工資,及工資級別


三、自連接

自連接 是指在同一張表連接查詢。


?練習
1、顯示員工?FORD?的上級領導的編號和姓名(mgr?是員工領導的編號 ——?empno
(1)使用的子查詢

先找 FORD 的上級領導的編號(emp),再根據領導的編號來找領導的信息(emp)。


(2)使用多表查詢(自查詢)
  • 使用到表的別名
from emp e1, emp e2,給自己的表起別名,因為要先做笛卡爾積,所以別名可以先識別。


四、子查詢

子查詢是指嵌入在其他? sql? 語句中的? select? 語句,也叫嵌套查詢。
  • 目前學習到的子查詢都在 where 子句中充當判斷條件。
  • 任何時刻,查詢出來的臨時結構,本質在邏輯上也是表結構。

1、單行子查詢

返回一行記錄的子查詢。
  • 顯示?SMITH?同一部門的員工


2、多行子查詢

返回多行記錄的子查詢。

(1)in 關鍵字

in 關鍵字用來判斷一個對應的列值是否在某個集合當中,只要在集合當中,說明查找成功。

查詢和? 10? 號部門的工作崗位相同的雇員的名字,崗位,工資,部門號,但是不包含? 10? 自己的。
擴展:除了上面的要求以外,還需要顯示出對應員工所屬崗位的名字。

(2)all 關鍵字

all 關鍵字表示與所有的值作比較。

顯示工資比部門? 30? 的所有員工的工資高的員工的姓名、工資和部門號。
另一種寫法:

(3)any 關鍵字

amy 關鍵字表示與任意的值作比較。

顯示工資比部門?30?的任意員工的工資高的員工的姓名、工資和部門號(包含自己部門的員工)。


3、多列子查詢

  • 單行子查詢是指子查詢只返回單列,單行數據。
  • 多行子查詢是指返回單列多行數據,都是針對單列而言的,而多列子查詢則是指查詢返回多個列數據的子查詢語句。

?練習
查詢和?SMITH?的部門和崗位完全相同的所有雇員,不含?SMITH?本人


4、在?from?子句中使用子查詢

子查詢語句出現在? from? 子句中。
這里要用到數據查詢的技巧,把一個子查詢當做一個臨時表使用。

?練習
(1)顯示每個高于自己部門平均工資的員工的姓名、部門、工資、平均工資
  • 獲取各個部門的平均工資,將其看作臨時表
擴展:除了上面的要求以外,還需要顯示出對應部門的辦公地點。

(2)查找每個部門工資最高的人的姓名、工資、部門、最高工資


(3)顯示每個部門的信息(部門名,編號,地址)和人員數量
a. 方法?1:使用多表

解決多表問題的本質:(多表的指導思想)

想辦法將多表轉化為單表,所以在?MySQL 中,所有 select 的問題全都可以轉成單表問題。?


b. 方法 2:使用子查詢(推薦)
  • 對 emp 表進行人員統計

  • 將上面的表看作臨時表

5、合并查詢

在實際應用中,為了合并多個? select? 的執行結果,可以使用集合操作符 union union all。

(1)union
該操作符用于取得兩個結果集的并集。當使用該操作符時, 自動去掉結果集中的重復行
練習 —— 將工資大于?2500?或職位是?MANAGER?的人找出來


(2)union all

該操作符用于取得兩個結果集的并集。當使用該操作符時不會去掉結果集中的重復行

練習 ——?將工資大于?25000?或職位是?MANAGER 的人找出來

注意:select 如果要使用 union / union all 來拼接兩個結果,前提是必須保證兩個表的列數是相同的。

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/news/713599.shtml
繁體地址,請注明出處:http://hk.pswp.cn/news/713599.shtml
英文地址,請注明出處:http://en.pswp.cn/news/713599.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

韋東山嵌入式Liunx入門驅動開發四

文章目錄 一、異常與中斷的概念及處理流程1-1 中斷的引入1-2 棧(1) CPU實現a ab的過程(2) 進程與線程 1-3 Linux系統對中斷處理的演進1-4 Linux 中斷系統中的重要數據結構(1) irq_desc 結構體(2) irqaction 結構體(3) irq_data 結構體(4) irq_domain 結構體(5) irq_domain 結構…

Redis入門與應用

Redis入門與應用 Redis的技術全景 Redis一個開源的基于鍵值對(Key-Value)NoSQL數據庫。使用ANSI C語言編寫、支持網絡、基于內存但支持持久化。性能優秀,并提供多種語言的API。 兩大維度 兩大維度:應用維度、底層原理維度 我們…

Java面試題:解釋Java內存模型中的棧內存和本地方法棧的區別,解釋Java中的垃圾回收機制中的增量收集算法,解釋Java內存模型中的直接內存的作用

Java內存模型與JVM面試題解析 在Java面試中,對Java內存模型(JMM)的理解是衡量候選人是否具備扎實Java功底的重要指標。JMM涵蓋了JVM的內存結構,包括堆、棧、方法區等關鍵組件,以及垃圾回收機制等核心概念。下面&#…

記一次dockerfile無法構建問題追溯

我有一個dockerfile如下: ENTRYPOINT ["/sbin/tini","-g", "--"] CMD /home/scrapy/start.sh 我原本的用意是先啟動tini,再執行下面的cmd命令啟動start.sh。 為啥要用tini? 因為我的這個docker…

git介紹4.2

git(版本控制工具) 一、git 介紹 1、git是目前世界上最先進的分布式版本控制系統,可以有效,高速的處理從小到大的項目版本管理。 2、git是linux torvalds 為了幫助管理linux內核開發二開發的一個開放源碼的版本控制軟件。 3、git作用:更好…

谷歌內部文件泄露:開源AI將領先谷歌與OpenAI

摘要: 一個谷歌研究員的內部文件透露,當前的人工智能(AI)競賽中,谷歌和OpenAI可能無法取勝。開源AI項目因其快速創新和低成本實現而已在悄悄領先,它們表現出在自定義性、隱私保護、以及性能方面的明顯優勢。…

PageHelper開源框架解讀

在使用springboot開發系統時&#xff0c;列表查詢經常會用PageHelper來進行分頁。使用起來很方便&#xff0c;但從未想過它的實現原理&#xff0c;所以對其進行解讀。 Service public class ScUserServiceImpl extends ServiceImpl<ScUserMapper, ScUser> implements IS…

WIN10 無密碼自動登錄

1、家里重裝了一下WIN10系統&#xff0c;第一次登陸居然用了微軟網站賬號&#xff0c;結果密碼忘記了&#xff0c;后面只能用PIN碼登陸系統。 2、需要登錄微軟的網站修改密碼&#xff1a; Microsoft account | Sign In or Create Your Account Today – Microsoft 3、在運行…

Linux-Prnt10:幾款國際打印機

這周接觸到惠普國際生產的幾款打印機設備&#xff0c;hplip的官網更新記錄里居然都沒有&#xff0c;特地確認了下其中緣由。這三款設備的型號分別是mpressora HP Laser 107w、mpressora Multifuncional HP Laser MFP 135a、mpressora Multifuncional HP Laser MFP 135w&#xf…

APP自動化測試-入門示例

入門示例 通過上一篇博客APP自動化測試介紹-CSDN博客的學習&#xff0c;相信大家對APP自動化測試已經有了一定的了解&#xff0c;下面演示一下入門示例 1. 配置Appium 1.1. 點擊Appium圖標&#xff0c;打開服務器&#xff1a; 1.2. 點擊Edit Configurations,進入配置頁面&am…

【LeetCode】【滑動窗口長度不固定】978 最長湍流子數組

1794.【軟件認證】最長的指定瑕疵度的元音子串 這個例題&#xff0c;是滑動窗口中長度不定求最大的題目&#xff0c;在看題之前可以先看一下【leetcode每日一題】【滑動窗口長度不固定】案例。 題目描述 定義&#xff1a;開頭和結尾都是元音字母&#xff08;aeiouAEIOU&…

Python腳本之打印乘法口訣表

Python腳本之打印乘法口訣表 for i in range(1, 10):for j in range(1, i 1):print(f"{j} * {i} {i * j}", end"\t")print()

GIT基本的命令

文章目錄 04.GIT本地操作-初始化工作區內容小結 05.GIT本地操作-add與commit目標內容小結 06.GIT本地操作-差異比較目標內容小結 07.GIT本地操作-版本回退目標內容小結 08.GIT本地操作-修改撤消目標內容小結 09.GIT本地操作-總結 04.GIT本地操作-初始化工作區 內容 初始化工作…

Java對象大小計算

概述 在實際應用中&#xff0c;尤其是在進行JVM調優時&#xff0c;理解并正確估計對象大小是非常重要的&#xff0c;因為這直接影響到內存分配、垃圾回收效率以及應用程序的整體性能。 對象的組成 在Java中&#xff0c;計算一個對象的大小是為了了解它在內存中占用的確切空間…

【c++基礎】挑戰賽第二題——放大的X

說明 請你編程畫一個放大的’X’&#xff08;大寫字母&#xff09;。 如3*3的’X’應如下所示&#xff1a; x xxx x 5*5的’X’如下所示&#xff1a; X XX XXX X X X 輸入數據 有一個正奇數n&#xff08;3 < n < 79&#xff09;&#xff0c;表示放大的規格。 …

m位數問題(c++題解)

題目描述 考官只給兩個整數n和m&#xff08;1 < n < 8&#xff0c;1< m <5&#xff09;&#xff0c;要求選手從1,2,…,n中取出m個數字&#xff0c;組成一個m位整數&#xff0c;統計所有的m位整數中一共有多少個素數。 如n3,m2時&#xff0c;符合條件的整數有&…

(C語言) time庫-日期和時間工具

文章目錄 ?介紹?常量??CLOCKS_PER_SEC ?類型??tm??time_t??clock_t??timespec (C11) ?函數-時間操作??time&#x1f3f7;?返回紀元開始經過的當前系統日歷時間??clock&#x1f3f7;?返回未加工的程序啟動時開始經過的處理器時間??difftime&#x1f3f7;?…

(delphi11最新學習資料) Object Pascal 學習筆記---第6章第3節(字符串連接)

6.3.3 字符串連接 ? 我已經提到過&#xff0c;與其他語言不同&#xff0c;Object Pascal 完全支持直接字符串連接&#xff0c;這實際上是一個相當快的操作。在本章中&#xff0c;我將向您展示一些字符串連接代碼和一些速度測試。稍后&#xff0c;在第 18 章中&#xff0c;我將…

第十五天-爬蟲項目實戰

目錄 1.介紹 2.代碼 1.main.py 2.PageSider.py 3.DetailSpider.py 4.DataParse.py 5.Constant.py 6.HanderRequest.py 1.介紹 1. 使用多線程爬取網站 2.爬取數據后保存至excel 3.爬取網站(僅做測試)網創類項目爬取&#xff1a;https://www.maomp.com/ 4..實現效果 …

python66-Python的循環之常用工具函數

使用zip()函數可以把兩個列表“壓縮”成一個zip對象(可迭代對象),這樣就可以使用一個循環并行遍歷兩個列表。為了測試 zip()函數的功能,我們可以先在交互式解釋器中“試驗”一下該函數的功能。 # !/usr/bin/env python# -*- coding: utf-8 -*-# @Time : 2024/01# @Author : …