時間:2023-03-06來源:系統城裝機大師作者:佚名
給定三張表(學生表、科目表、成績表),查出各科成績最高的學生的信息(學號、姓名、科目名稱、成績)。三張表下所示。
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
該步驟的結果如下所示:
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
該步驟的結果如下所示:
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
最終結果如下:
完成本題中遇到的一些錯誤,簡單總結以下
對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,因此是錯誤的??偨Y來說group by 只進行了分組,記錄中的其他字段需要另外想辦法查詢。
關于在一個表中顯示三個數據庫表字段的查詢。
首先要找的三個表中字段的對應關系,以哪一張表為主表(其他表字段增添這個主表上)作為顯示頁面上。
上代碼
查詢主表: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代碼
1 2 3 4 5 6 7 8 9 10 |
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三表聯合查詢操作的文章就介紹到這了!
2022-12-15
windows系統下SQL Server 2008超詳細安裝教程2022-12-06
Oracle中sql語句如何執行日志查詢2022-11-11
mdf文件播放方法很多用戶在電腦上操作的時候都遇到過想要復制mdf文件卻發現無法復制的情況吧,那么遇到了這個問題該如何去解決呢?今天就為大家帶來了解決的方法一起看看吧。...
2022-11-11
iso是目前非常流行的通用光盤映像文件格式,很多的用戶都想把mdf格式的文件轉換成iso格式但苦于不會操作,下面就為大家帶來詳細的操作方法一起看看吧。...
2022-11-11