Mysql整理二 - 常見查詢語句面試題(附原表)

表結構,創建原表的代碼在最后

-- cid課程id; tid老師id; sid學生id;
select * from t_mysql_course;
select * from t_mysql_score;
select * from t_mysql_student;
select * from t_mysql_teacher;

1.?查詢" 01 “課程比” 02 "課程成績高的學生的信息及課程分數

-- 查詢" 01 “課程比” 02 "課程成績高的學生的信息及課程分數
-- 把課程01和課程02單獨拉出來,再進行對比,為了確保能對應成功,需要s1.sid = s.sid這個條件
-- 為了確保對比的是同一個人,需要有s1.sid = s2.sid
select s.*,s1.score a, s2.score b
from
t_mysql_student s,
(select * from t_mysql_score where cid = "01") s1,
(select * from t_mysql_score where cid = "02") s2
where
s1.sid = s2.sid and
s1.sid = s.sid and
s1.score > s2.score;

2.?查詢同時存在 " 01 “課程和” 02 "課程的情況 SELECT

-- 查詢同時存在 " 01 “課程和” 02 "課程的情況 
select s1.sid from 
(select * from t_mysql_score where cid = "01") as s1 
inner join
(select * from t_mysql_score where cid = "02") as s2
where s1.sid = s2.sid;

3.?查詢存在 " 01 “課程但可能不存在” 02 "課程的情況 ( 不存在時顯示為 NULL )?

-- 查詢不存在" 01 “課程但存在” 02 "課程的情況
select s.* from t_mysql_score s where sid 
not in (select sid from t_mysql_score where cid = "01") and s.cid = "02";

4.?查詢平均成績大于等于 60 分的同學的學生編號和學生姓名和平均成績

-- 查詢平均成績大于等于 60 分的同學的學生編號和學生姓名和平均成績
select s.sid,s.sname,s2.score from t_mysql_student s
, (select sid,avg(score) as score from t_mysql_score group by sid) as s2 
where s.sid = s2.sid and s2.score >= 60;

5.?查詢所有同學的學生編號、學生姓名、選課總數、所有課程的總成績(沒成績的顯示為 null)

-- 查詢所有同學的學生編號、學生姓名、選課總數、所有課程的總成績(沒成績的顯示為 null)
select s.sid,s.sname,s2.num_cid,s2.sum_score 
from t_mysql_student s,
(select s1.sid,count(cid) as num_cid,sum(score) as sum_score from t_mysql_score s1 group by sid) as s2
where s.sid = s2.sid;

6.?查詢學過「張三」老師授課的同學的信息

-- 查詢學過「張三」老師授課的同學的信息select st.sid,st.sname,st.sage,st.ssex from t_mysql_student st,
t_mysql_course co, 
t_mysql_score sc, 
t_mysql_teacher te
where te.tname like '張三' and 
te.tid = co.tid and 
co.cid = sc.cid and 
sc.sid = st.sid;

7.?查詢沒有學全所有課程的同學的信息

-- 查詢沒有學全所有課程的同學的信息
select s.*, COUNT(sc.cid) as count_cid 
from t_mysql_student s 
join t_mysql_score sc 
on s.sid = sc.sid 
group by sc.sid 
having 
COUNT(sc.cid) < (select count(*) from t_mysql_course);

8.?查詢沒學過"張三"老師講授的任一門課程的學生姓名

-- 查詢沒學過"張三"老師講授的任一門課程的學生姓名
select * from t_mysql_student where sid 
not in 
(select sc.sid from t_mysql_course co, t_mysql_score sc, t_mysql_teacher te
where te.tname like '張三' and te.tid = co.tid and co.cid = sc.cid);

9.?查詢兩門及其以上不及格課程的同學的學號,姓名及其平均成績

-- 查詢兩門及其以上不及格課程的同學的學號,姓名及其平均成績
select s.sid,s.sname,round(avg(sc.score),2) as score 
from t_mysql_student s,t_mysql_score sc
where s.sid = sc.sid
and sc.score < 60 group by sid having count(sc.cid) >= 2;

10.?檢索" 01 "課程分數小于 60,按分數降序排列的學生信息

-- 檢索" 01 "課程分數小于 60,按分數降序排列的學生信息
select 
s.sid,s.sname,sc.score
from 
t_mysql_student s,t_mysql_score sc
where 
s.sid = sc.sid
and sc.score < 60 
and sc.cid = "01" 
order by score desc;

11.?按平均成績從高到低顯示所有學生的所有課程的成績以及平均成績

-- 按平均成績從高到低顯示所有學生的所有課程的成績以及平均成績
select 
s.sname,s.sid,round(avg(sc.score),2) as avg_score,
max(CASE WHEN sc.cid = "01" THEN sc.score END )語文,
max(CASE WHEN sc.cid = "02" THEN sc.score END )數學,
max(CASE WHEN sc.cid = "03" THEN sc.score END )英語
from 
t_mysql_student s,t_mysql_score sc
where 
s.sid = sc.sid 
group by s.sid
order by avg(sc.score) desc;

12.?-- 以如下形式顯示:課程 ID,課程 name,最高分,最低分,平均分,及格率,中等率,優良率,優秀率及格為>=60,中等為:70-80,優良為:80-90,優秀為:>=90
-- 要求輸出課程號和選修人數,查詢結果按人數降序排列,若人數相同,按課程號升序排列

-- 以如下形式顯示:課程 ID,課程 name,最高分,最低分,平均分,及格率,中等率,優良率,優秀率及格為>=60,中等為:70-80,優良為:80-90,優秀為:>=90
-- 要求輸出課程號和選修人數,查詢結果按人數降序排列,若人數相同,按課程號升序排列select
co.cid, co.cname, max(sc.score) 最高分, min(sc.score) 最低分, round(avg(sc.score),2) 平均分,
concat(round(sum(if (sc.score > 60, 1,0))/count(sc.score)*100,2),'%') 及格率
from t_mysql_course co,t_mysql_score sc
where co.cid = sc.cid
group by co.cid;
SUM(IF(sc.score > 60, 1, 0)):這部分計算了成績大于 60 分的記錄的數量。
如果某條記錄的成績大于 60 分,那么 IF 函數返回 1,否則返回 0。然后,
SUM 函數將這些值相加,得到及格的記錄數。COUNT(sc.score):這部分計算了總記錄數,無論成績是否及格。sum(...) / count(sc.score):這部分計算及格的記錄數除以總記錄數,得到及格率。ROUND(..., 2):這部分使用 ROUND 函數將計算結果保留兩位小數。CONCAT(..., '%'):最后,CONCAT 函數將計算結果和百分號字符 "%" 連接在一起,
得到一個帶百分號的及格率字符串。

13. 原表

/*Navicat Premium Data TransferSource Server         : localhostSource Server Type    : MySQLSource Server Version : 80018Source Host           : localhost:3306Source Schema         : mybatis_ssmTarget Server Type    : MySQLTarget Server Version : 80018File Encoding         : 65001Date: 04/07/2023 23:53:33
*/SET NAMES utf8mb4;
SET FOREIGN_KEY_CHECKS = 0;-- ----------------------------
-- Table structure for t_mysql_course
-- ----------------------------
DROP TABLE IF EXISTS `t_mysql_course`;
CREATE TABLE `t_mysql_course`  (`cid` varchar(20) CHARACTER SET utf8mb4 COLLATE utf8mb4_general_ci NOT NULL COMMENT '課程編號',`cname` varchar(20) CHARACTER SET utf8mb4 COLLATE utf8mb4_general_ci NOT NULL COMMENT '課程名稱',`tid` varchar(20) CHARACTER SET utf8mb4 COLLATE utf8mb4_general_ci NOT NULL COMMENT '教師編號',PRIMARY KEY (`cid`) USING BTREE
) ENGINE = InnoDB CHARACTER SET = utf8mb4 COLLATE = utf8mb4_general_ci COMMENT = '課程信息表' ROW_FORMAT = Dynamic;-- ----------------------------
-- Records of t_mysql_course
-- ----------------------------
INSERT INTO `t_mysql_course` VALUES ('01', '語文', '02');
INSERT INTO `t_mysql_course` VALUES ('02', '數學', '01');
INSERT INTO `t_mysql_course` VALUES ('03', '英語', '03');-- ----------------------------
-- Table structure for t_mysql_score
-- ----------------------------
DROP TABLE IF EXISTS `t_mysql_score`;
CREATE TABLE `t_mysql_score`  (`sid` varchar(20) CHARACTER SET utf8mb4 COLLATE utf8mb4_general_ci NOT NULL COMMENT '學生編號,外鍵',`cid` varchar(20) CHARACTER SET utf8mb4 COLLATE utf8mb4_general_ci NOT NULL COMMENT '課程編號,外鍵',`score` float NULL DEFAULT 0 COMMENT '成績',INDEX `sid`(`sid`) USING BTREE,INDEX `cid`(`cid`) USING BTREE,CONSTRAINT `t_mysql_score_ibfk_1` FOREIGN KEY (`sid`) REFERENCES `t_mysql_student` (`sid`) ON DELETE RESTRICT ON UPDATE RESTRICT,CONSTRAINT `t_mysql_score_ibfk_2` FOREIGN KEY (`cid`) REFERENCES `t_mysql_course` (`cid`) ON DELETE RESTRICT ON UPDATE RESTRICT
) ENGINE = InnoDB CHARACTER SET = utf8mb4 COLLATE = utf8mb4_general_ci COMMENT = '成績信息表' ROW_FORMAT = Dynamic;-- ----------------------------
-- Records of t_mysql_score
-- ----------------------------
INSERT INTO `t_mysql_score` VALUES ('01', '01', 80);
INSERT INTO `t_mysql_score` VALUES ('01', '02', 90);
INSERT INTO `t_mysql_score` VALUES ('01', '03', 99);
INSERT INTO `t_mysql_score` VALUES ('02', '01', 70);
INSERT INTO `t_mysql_score` VALUES ('02', '02', 60);
INSERT INTO `t_mysql_score` VALUES ('02', '03', 80);
INSERT INTO `t_mysql_score` VALUES ('03', '01', 80);
INSERT INTO `t_mysql_score` VALUES ('03', '02', 80);
INSERT INTO `t_mysql_score` VALUES ('03', '03', 80);
INSERT INTO `t_mysql_score` VALUES ('04', '01', 50);
INSERT INTO `t_mysql_score` VALUES ('04', '02', 30);
INSERT INTO `t_mysql_score` VALUES ('04', '03', 20);
INSERT INTO `t_mysql_score` VALUES ('05', '01', 76);
INSERT INTO `t_mysql_score` VALUES ('05', '02', 87);
INSERT INTO `t_mysql_score` VALUES ('06', '01', 31);
INSERT INTO `t_mysql_score` VALUES ('06', '03', 34);
INSERT INTO `t_mysql_score` VALUES ('07', '02', 89);
INSERT INTO `t_mysql_score` VALUES ('07', '03', 98);-- ----------------------------
-- Table structure for t_mysql_student
-- ----------------------------
DROP TABLE IF EXISTS `t_mysql_student`;
CREATE TABLE `t_mysql_student`  (`sid` varchar(20) CHARACTER SET utf8mb4 COLLATE utf8mb4_general_ci NOT NULL COMMENT '學生編號',`sname` varchar(20) CHARACTER SET utf8mb4 COLLATE utf8mb4_general_ci NOT NULL COMMENT '學生名稱',`sage` varchar(20) CHARACTER SET utf8mb4 COLLATE utf8mb4_general_ci NOT NULL COMMENT '學生年齡',`ssex` varchar(20) CHARACTER SET utf8mb4 COLLATE utf8mb4_general_ci NOT NULL COMMENT '學生性別',PRIMARY KEY (`sid`) USING BTREE
) ENGINE = InnoDB CHARACTER SET = utf8mb4 COLLATE = utf8mb4_general_ci COMMENT = '學生信息表' ROW_FORMAT = Dynamic;-- ----------------------------
-- Records of t_mysql_student
-- ----------------------------
INSERT INTO `t_mysql_student` VALUES ('01', '趙雷', '1990-01-01', '男');
INSERT INTO `t_mysql_student` VALUES ('02', '錢電', '1990-12-21', '男');
INSERT INTO `t_mysql_student` VALUES ('03', '孫風', '1990-12-20', '男');
INSERT INTO `t_mysql_student` VALUES ('04', '李云', '1990-12-06', '男');
INSERT INTO `t_mysql_student` VALUES ('05', '周梅', '1991-12-01', '女');
INSERT INTO `t_mysql_student` VALUES ('06', '吳蘭', '1992-01-01', '女');
INSERT INTO `t_mysql_student` VALUES ('07', '鄭竹', '1989-01-01', '女');
INSERT INTO `t_mysql_student` VALUES ('09', '張三', '2017-12-20', '女');
INSERT INTO `t_mysql_student` VALUES ('10', '李四', '2017-12-25', '女');
INSERT INTO `t_mysql_student` VALUES ('11', '李四', '2012-06-06', '女');
INSERT INTO `t_mysql_student` VALUES ('12', '趙六', '2013-06-13', '女');
INSERT INTO `t_mysql_student` VALUES ('13', '孫七', '2014-06-01', '女');-- ----------------------------
-- Table structure for t_mysql_teacher
-- ----------------------------
DROP TABLE IF EXISTS `t_mysql_teacher`;
CREATE TABLE `t_mysql_teacher`  (`tid` varchar(20) CHARACTER SET utf8mb4 COLLATE utf8mb4_general_ci NOT NULL COMMENT '教師編號',`tname` varchar(20) CHARACTER SET utf8mb4 COLLATE utf8mb4_general_ci NOT NULL COMMENT '教師名稱',PRIMARY KEY (`tid`) USING BTREE
) ENGINE = InnoDB CHARACTER SET = utf8mb4 COLLATE = utf8mb4_general_ci COMMENT = '教師信息表' ROW_FORMAT = Dynamic;-- ----------------------------
-- Records of t_mysql_teacher
-- ----------------------------
INSERT INTO `t_mysql_teacher` VALUES ('01', '張三');
INSERT INTO `t_mysql_teacher` VALUES ('02', '李四');
INSERT INTO `t_mysql_teacher` VALUES ('03', '王五');SET FOREIGN_KEY_CHECKS = 1;

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

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

相關文章

uniapp軟鍵盤談起遮住輸入框和頭部被頂起的問題解決

推薦&#xff1a; pages.json中配置如下可解決頭部被頂起和表單被遮住的問題。 { "path": "pages/debug/protocol/tagWord", "style": { "app-plus": { "soft…

01.setup,reactive,ref,computed,watch學習---2023新版Vue3基礎入門到實戰項目

1.Vue3組合式 2.創建vue3項目 2.1認識create-vue create-vue是官方新的腳手架工具&#xff0c;vite下一代構建工具 node -v >16 npm init vuelatest 2.2 setup 原始寫法 <script> export default {//執行時機比beforeCreate早//獲取不到this//數據和函數必須ret…

Java實戰:高效提取PDF文件指定坐標的文本內容

前言 臨時接到一個緊急需要處理的事項。業務側一個同事有幾千個PDF文件需要整理&#xff1a;需要從文件中的指定位置獲取對應的編號和地址。 要的急&#xff0c;工作量大。所以就問到技術部有沒有好的解決方案。 問技術的話就只能寫個demo跑下了。 解決辦法 1. 研究下PDF文檔…

案例15 Spring Boot入門案例

1. 選擇Spring Initializr快速構建項目 ? 2. 設置項目信息 ? 3. 選擇依賴 ? 4. 設置項目名稱 ? 5. 項目結構 ? 6. 項目依賴 自動配置了Spring MVC、內置了Tomcat、配置了Logback(日志)、配置了JSON。 ? 7. 創建HelloController類 com.wfit.boot.hello目錄下創建HelloCo…

Less和Sass的原理和用法

一、原理 1.1 Less定義&#xff1a;是一種動態的樣式語言,使CSS變成一種動態的語言特性&#xff0c;如變量、繼承、運算、函數。Less既可以在客戶端上面運行(支持IE6以上版本、Webkit、Firefox),也可以在服務端運行(Node.js) 1.2 SaSS定義&#xff1a;是一種動態樣式語言&#…

開發過程中遇到的問題以及解決方法

鞏固基礎&#xff0c;砥礪前行 。 只有不斷重復&#xff0c;才能做到超越自己。 能堅持把簡單的事情做到極致&#xff0c;也是不容易的。 開發過程中遇到的問題以及解決方法 簡單易用的git命令 git命令&#xff1a; 查看有幾個分支&#xff1a;git branch -a 切換分支&#…

Azure創建第一個虛擬機

首先&#xff0c;登錄到 Azure 門戶 (https://portal.azure.com/)。在 Azure 門戶右上角&#xff0c;點擊“虛擬機”按鈕&#xff0c;并點擊創建&#xff0c;創建Azure虛擬機。 在虛擬機創建頁面中&#xff0c;選擇所需的基本配置&#xff0c;包括虛擬機名稱、操作系統類型和版…

【JVM】JVM 調優的參數都有哪些?

文章目錄 1. 設置堆空間大小2. 虛擬機棧的設置3. 年輕代中Eden區和兩個Survivor區的大小比例4. 年輕代晉升老年代閾值5. 設置垃圾回收收集器 1. 設置堆空間大小 設置堆的初始大小和最大大小&#xff0c;為了防止垃圾收集器在初始大小、最大大小之間收縮堆而產生額外的時間&…

python編程小游戲簡單的,python小游戲編程100例

大家好&#xff0c;給大家分享一下python編程小游戲簡單的&#xff0c;很多人還不知道這一點。下面詳細解釋一下。現在讓我們來看看&#xff01; 不會python就不能用python開發入門級的小游戲&#xff1f; 當然不是&#xff0c;我收集了十個python入門小游戲的源碼和教程&#…

分支語句和循環語句(1)

這篇文章我們詳細的把分支語句和循環語句給大家進行講解。 分支語句&#xff1a; if switch 循環語句&#xff1a; while for do while goto語句&#xff1a; 1.什么是語句&#xff1f; C語句可分為以下五類&#xff1a; 1. 表達式語句 2. 函數調用語句 3. 控制…

qt自己實現方便的線程管理類

看本博客之前&#xff0c;可以先看看我這篇多線程博客&#xff1a;qt多線程使用方式_我是標同學的博客-CSDN博客

ORCA優化器淺析——CDXLOperator Base class for operators in a DXL tree

如上圖所示&#xff0c;CDXLOperator作為Base class for operators in a DXL tree&#xff0c;其子類CDXLLogical、CDXLScalar、CDXLPhysical作為邏輯節點、物理節點和Scalar節點的DXL表示類&#xff0c;因此其包含了這些類的共同部分特性&#xff0c;比如獲取其DXL節點表示的函…

Qt 文件對話框使用 Deepin風格

當你在Deepin或UOS 上開發 Qt 程序時&#xff0c;如果涉及到文件對話框功能&#xff0c;那么就會遇到調用原生窗口的問題。 如果你使用的是官方的Qt版本&#xff0c;那么在Deepin或者UOS系統上&#xff0c;彈出的文件對話框會是如下這樣&#xff1a; 而Deepin或UOS系統提供的默…

可視化高級繪圖技巧100篇-總論

前言 優秀的數據可視化作品可以用三個關鍵詞概括&#xff1a;準確、清晰、優雅。 準確&#xff1a;精準地反饋數據的特征信息&#xff08;既不遺漏也不冗余&#xff0c;不造成讀者疏漏&誤讀細節&#xff09; 清晰&#xff1a;獲取圖表特征信息的時間越短越好 優雅&…

Gitlab CI/CD筆記-第二天-主機套接字進行構建并push鏡像。

一、安裝gitlab-runner 1.可以是linux也可以是docker的 2.本文說的是docker安裝部署的。 二、直接上.gitlab-ci.yml stages: # List of stages for jobs, and their order of execution - build-image build-image-job: stage: build-image image: harbor.com:543/docke…

企業計算機服務器中了360后綴勒索病毒怎么辦,勒索病毒解密數據恢復

隨著計算機技術的不斷發展&#xff0c;企業的辦公系統得到了很大提升&#xff0c;但是隨之而來的網絡安全威脅也不斷增加&#xff0c;勒索病毒的攻擊事件時有發生。近期&#xff0c;我們收到某地連鎖超市的求助&#xff0c;企業的計算機服務器遭到了360后綴勒索病毒攻擊&#x…

C#四個字節十六進制與單精度浮點數互轉

C#四個字節十六進制與單精度浮點數互轉可以使用自帶的函數,也可以自己寫 實例如下: using System; using System.Collections.Generic; using System.Linq; using System.Text; using System.Threading.Tasks;namespace floatDemo {class Program{//首先設置:項目->屬性…

html練習

html練習 工具代碼運行結果 工具 HBuilder X 代碼 <!DOCTYPE html> <html><head><meta charset"utf-8"><title>圖靈之家</title></head><body><h1>圖靈之家</h1><br><br><h2>我的…

Maxwell 數據同步使用教程

Maxwell 數據同步使用教程 Maxwell 是一個開源的 MySQL 數據同步工具&#xff0c;它可以提供可靠的、實時的數據復制服務。它的特點是將 MySQL 的 binlog 解析成易于理解、易于使用的 JSON 格式&#xff0c;并將其發送到 Kafka 或其他消息隊列&#xff0c;方便消費者進行數據處…

使用幾何和線性代數從單個圖像進行 3D 重建

使用幾何和線性代數從單個圖像進行 3D 重建 薩蒂亞 一、說明 3D重構是一個挑戰性題目&#xff0c;而且這個新穎的題目正處于啟發和膨脹階段&#xff1b;因此&#xff0c;各種各樣的嘗試層出不窮&#xff0c;本篇說明嘗試的一種&#xff0c;至于其它更多的嘗試&#xff0c;我們在…