MySQL三表聯(lián)合查詢操作舉例
一、題目概述
給定三張表(學(xué)生表、科目表、成績表),查出各科成績最高的學(xué)生的信息(學(xué)號、姓名、科目名稱、成績)。三張表下所示。



二、查詢思路
1.查詢出各科的最高成績
select max(s.`Score`) as MaxScore from score s group by s.`SubjectId`
2.查詢出各科的最高成績及對應(yīng)的科目和學(xué)生編號(關(guān)鍵步驟)
此處通過子查詢完成。根據(jù)步驟1中查出的最高成績,再查成績表中成績等于最高成績且科目相對應(yīng)的記錄
select b.* from ( select max(s.`Score`) as MaxScore,s.`SubjectId` as SubId from score s group by s.`SubjectId`) f,score b where b.`SubjectId` = f.SubId and b.`Score` = f.MaxScore
該步驟的結(jié)果如下所示:

3. 查詢出各科的最高成績及對應(yīng)的科目名稱和學(xué)生編號
步驟2只涉及了成績表,由于該表不含成績名稱,需要與科目表進(jìn)行聯(lián)表查詢
SELECT b.`StudentId`,f.SubName,b.`Score` FROM ( SELECT MAX(s.`Score`) AS MaxScore,s.`SubjectId` AS SubId,sub.`Name` AS SubName FROM score s LEFT JOIN SUBJECT AS sub ON s.`SubjectId` = sub.`SubjectNo` GROUP BY s.`SubjectId`)f,score b WHERE b.`SubjectId` = f.SubId AND b.`Score` = f.MaxScore
該步驟的結(jié)果如下所示:

4. 查詢出各科的最高成績及對應(yīng)的科目名稱和學(xué)生姓名
同理,再與學(xué)生表進(jìn)行一次聯(lián)表查詢,查出學(xué)生姓名
SELECT stu.Name,t.* FROM
(SELECT b.`StudentId` AS Sid,f.SubName AS SubName,b.`Score` AS Score FROM
(SELECT MAX(s.`Score`) AS MaxScore,sub.`SubjectNo` AS SubNo,sub.`Name` AS SubName
FROM score s LEFT JOIN SUBJECT AS sub ON s.`SubjectId` = sub.`SubjectNo` GROUP BY sub.`SubjectNo`)
f,score b WHERE b.`StudentId` = f.SubNo AND b.`Score` = f.MaxScore)
t LEFT JOIN student stu ON stu.StudentNo = t.Sid ORDER BY t.Score
最終結(jié)果如下:

三、錯誤總結(jié)
完成本題中遇到的一些錯誤,簡單總結(jié)以下
對group by的結(jié)果理解有問題。下面的SQL查詢嘗試查出最高成績對應(yīng)的學(xué)生Id,
SELECT s.`StudentId` AS Sid, MAX(s.`Score`) AS MaxScore,sub.`Name` AS SubName FROM score s LEFT JOIN SUBJECT AS sub ON s.`SubjectId` = sub.`SubjectNo` GROUP BY s.`SubjectId`
實(shí)際上SQL查出的學(xué)生Id都是3,即對應(yīng)最高成績的Id是錯誤的。原因在于group by只是在select的查詢結(jié)果基礎(chǔ)上根據(jù)分組指定的關(guān)鍵字進(jìn)行分組,并將分組后的若干記錄的中第一條進(jìn)行展示,此處正好語數(shù)外分組的第一條記錄的學(xué)生Id都是3,因此是錯誤的??偨Y(jié)來說group by 只進(jìn)行了分組,記錄中的其他字段需要另外想辦法查詢。
附:sql 三個表聯(lián)合查詢(三表左聯(lián)查詢)
關(guān)于在一個表中顯示三個數(shù)據(jù)庫表字段的查詢。
首先要找的三個表中字段的對應(yīng)關(guān)系,以哪一張表為主表(其他表字段增添這個主表上)作為顯示頁面上。
上代碼
查詢主表:csb_accessories_bjgh的全部,csb_accessories_bjqd表,csb_asset_directory表,的aname,atypes,/assetname,assettypes的字段。
關(guān)系:csb_accessories_bjgh.accessoriesid = csb_accessories_bjqd.accessoriesid
以及 csb_accessories_bjgh.assetid = csb_asset_directory.assetid
這是sql代碼
SELECT csb_accessories_bjgh.*, csb_accessories_bjqd.aname, csb_accessories_bjqd.atypes, csb_asset_directory.assetname, csb_asset_directory.assettypes FROM (( csb_accessories_bjgh LEFT JOIN csb_accessories_bjqd ON csb_accessories_bjgh.accessoriesid = csb_accessories_bjqd.accessoriesid ) LEFT JOIN csb_asset_directory ON csb_accessories_bjgh.assetid = csb_asset_directory.assetid ) WHERE csb_accessories_bjgh.id IS NOT NULL
總結(jié)
到此這篇關(guān)于MySQL三表聯(lián)合查詢操作的文章就介紹到這了,更多相關(guān)MySQL三表聯(lián)合查詢內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
Mysql8創(chuàng)建用戶及賦權(quán)操作實(shí)戰(zhàn)記錄
一般在開發(fā)中,我們需要新建一個賬戶,并賦予某個數(shù)據(jù)庫的訪問權(quán)限,下面這篇文章主要給大家介紹了關(guān)于Mysql8創(chuàng)建用戶及賦權(quán)操作的相關(guān)資料,文中通過示例代碼介紹的非常詳細(xì),需要的朋友可以參考下2022-04-04
解決MySQL因不能創(chuàng)建臨時文件而導(dǎo)致無法啟動的方法
這篇文章主要跟大家介紹了關(guān)于解決MySQL因不能創(chuàng)建臨時文件而導(dǎo)致無法啟動的方法,文中通過示例代碼介紹了詳細(xì)的解決方法,對大家具有一定的的參考學(xué)習(xí)價值,需要的朋友們下面來一起看看吧。2017-06-06
安裝SQL server出現(xiàn)“服務(wù)沒有及時響應(yīng)啟動或控制請求”的解決方案
這篇文章主要給大家解決了安裝SQL server出現(xiàn)“服務(wù)沒有及時響應(yīng)啟動或控制請求”,文中有詳細(xì)的解決方案,有需要的同學(xué)可以參考閱讀下2023-08-08
MySQL開啟遠(yuǎn)程訪問權(quán)限的最新方法
這篇文章主要給大家介紹了關(guān)于MySQL開啟遠(yuǎn)程訪問權(quán)限的最新方法,在MySQL中,要實(shí)現(xiàn)遠(yuǎn)程訪問,首先需要在MySQL服務(wù)端上開啟相應(yīng)的權(quán)限,需要的朋友可以參考下2023-08-08
Mysql 5.6使用配置文件my.ini來設(shè)置長時間連接數(shù)據(jù)庫的問題
這篇文章主要介紹了Mysql 5.6使用配置文件my.ini來設(shè)置長時間連接數(shù)據(jù)庫,本文給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下2023-07-07

