文章详情

短信预约-IT技能 免费直播动态提醒

请输入下面的图形验证码

提交验证

短信预约提醒成功

MySQL三表联合查询操作举例

2023-03-06 07:27

关注

一、题目概述

给定三张表(学生表、科目表、成绩表),查出各科成绩最高的学生的信息(学号、姓名、科目名称、成绩)。三张表下所示。

图片表

科目表

成绩表

二、查询思路

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

该步骤的结果如下所示:

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

最终结果如下:

最终结果

三、错误总结

完成本题中遇到的一些错误,简单总结以下

对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三表联合查询内容请搜索我们以前的文章或继续浏览下面的相关文章希望大家以后多多支持我们!

阅读原文内容投诉

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

软考中级精品资料免费领

  • 历年真题答案解析
  • 备考技巧名师总结
  • 高频考点精准押题
  • 2024年上半年信息系统项目管理师第二批次真题及答案解析(完整版)

    难度     807人已做
    查看
  • 【考后总结】2024年5月26日信息系统项目管理师第2批次考情分析

    难度     351人已做
    查看
  • 【考后总结】2024年5月25日信息系统项目管理师第1批次考情分析

    难度     314人已做
    查看
  • 2024年上半年软考高项第一、二批次真题考点汇总(完整版)

    难度     433人已做
    查看
  • 2024年上半年系统架构设计师考试综合知识真题

    难度     221人已做
    查看

相关文章

发现更多好内容

猜你喜欢

AI推送时光机
位置:首页-资讯-数据库
咦!没有更多了?去看看其它编程学习网 内容吧
首页课程
资料下载
问答资讯