时间: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,因此是错误的。总结来说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三表联合查询操作的文章就介绍到这了!
2023-10-27
windows11安装SQL server数据库报错等待数据库引擎恢复句柄失败解决办法2023-10-27
SQL Server截取字符串函数操作常见方法2023-10-27
浅谈SELECT *会导致查询效率低的原因收缩数据文件通过将数据页从文件末尾移动到更靠近文件开头的未占用的空间来恢复空间,在文件末尾创建足够的空间后,可取消对文件末尾的数据页的分配并将它们返回给文件系统,本文给大家介绍SQL Server 数据库中的收缩数据...
2023-10-27