91超碰碰碰碰久久久久久综合_超碰av人澡人澡人澡人澡人掠_国产黄大片在线观看画质优化_txt小说免费全本

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

MySQL三表聯合查詢的方法是什么

發布時間:2023-03-07 16:00:53 來源:億速云 閱讀:172 作者:iii 欄目:開發技術

這篇文章主要介紹了MySQL三表聯合查詢的方法是什么的相關知識,內容詳細易懂,操作簡單快捷,具有一定借鑒價值,相信大家閱讀完這篇MySQL三表聯合查詢的方法是什么文章都會有所收獲,下面我們一起來看看吧。

一、題目概述

給定三張表(學生表、科目表、成績表),查出各科成績最高的學生的信息(學號、姓名、科目名稱、成績)。三張表下所示。

MySQL三表聯合查詢的方法是什么

MySQL三表聯合查詢的方法是什么

MySQL三表聯合查詢的方法是什么

二、查詢思路

1.查詢出各科的最高成績

select max(s.`Score`) as MaxScore from score s group by s.`SubjectId`

2.查詢出各科的最高成績及對應的科目和學生編號(關鍵步驟)

此處通過子查詢完成。根據步驟1中查出的最高成績,再查成績表中成績等于最高成績且科目相對應的記錄

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

該步驟的結果如下所示:

MySQL三表聯合查詢的方法是什么

3. 查詢出各科的最高成績及對應的科目名稱和學生編號

步驟2只涉及了成績表,由于該表不含成績名稱,需要與科目表進行聯表查詢

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

該步驟的結果如下所示:

MySQL三表聯合查詢的方法是什么

4. 查詢出各科的最高成績及對應的科目名稱和學生姓名

同理,再與學生表進行一次聯表查詢,查出學生姓名

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

最終結果如下:

MySQL三表聯合查詢的方法是什么

三、錯誤總結

完成本題中遇到的一些錯誤,簡單總結以下

對group by的結果理解有問題。下面的SQL查詢嘗試查出最高成績對應的學生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`

實際上SQL查出的學生Id都是3,即對應最高成績的Id是錯誤的。原因在于group by只是在select的查詢結果基礎上根據分組指定的關鍵字進行分組,并將分組后的若干記錄的中第一條進行展示,此處正好語數外分組的第一條記錄的學生Id都是3,因此是錯誤的。總結來說group by 只進行了分組,記錄中的其他字段需要另外想辦法查詢。

附:sql 三個表聯合查詢(三表左聯查詢)

關于在一個表中顯示三個數據庫表字段的查詢。

首先要找的三個表中字段的對應關系,以哪一張表為主表(其他表字段增添這個主表上)作為顯示頁面上。

上代碼

查詢主表:csb_accessories_bjgh的全部,csb_accessories_bjqd表,csb_asset_directory表,的aname,atypes,/assetname,assettypes的字段。

關系: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

關于“MySQL三表聯合查詢的方法是什么”這篇文章的內容就介紹到這里,感謝各位的閱讀!相信大家對“MySQL三表聯合查詢的方法是什么”知識都有一定的了解,大家如果還想學習更多知識,歡迎關注億速云行業資訊頻道。

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

合阳县| 贺兰县| 龙门县| 东兰县| 平定县| 新河县| 崇信县| 湘潭市| 香河县| 子洲县| 云和县| 拉萨市| 彭泽县| 资阳市| 乌拉特后旗| 和田市| 余江县| 枣庄市| 寿光市| 阳高县| 鄂托克旗| 大田县| 黑龙江省| 阿鲁科尔沁旗| 忻州市| 房山区| 田东县| 安吉县| 兰州市| 花垣县| 彩票| 河源市| 东辽县| 山东| 汶上县| 长宁县| 区。| 昌江| 襄汾县| 铜鼓县| 乐陵市|