Java学习者论坛

 找回密码
 立即注册

QQ登录

只需一步,快速开始

手机号码,快捷登录

恭喜Java学习者论坛(https://www.javaxxz.com)已经为数万Java学习者服务超过8年了!积累会员资料超过10000G+
成为本站VIP会员,下载本站10000G+会员资源,购买链接:点击进入购买VIP会员
JAVA高级面试进阶视频教程Java架构师系统进阶VIP课程

分布式高可用全栈开发微服务教程

Go语言视频零基础入门到精通

Java架构师3期(课件+源码)

Java开发全终端实战租房项目视频教程

SpringBoot2.X入门到高级使用教程

大数据培训第六期全套视频教程

深度学习(CNN RNN GAN)算法原理

Java亿级流量电商系统视频教程

互联网架构师视频教程

年薪50万Spark2.0从入门到精通

年薪50万!人工智能学习路线教程

年薪50万!大数据从入门到精通学习路线年薪50万!机器学习入门到精通视频教程
仿小米商城类app和小程序视频教程深度学习数据分析基础到实战最新黑马javaEE2.1就业课程从 0到JVM实战高手教程 MySQL入门到精通教程
查看: 345|回复: 0

[数据库学习]学习SQL多表连接(13)多表连接的综合运用

[复制链接]
  • TA的每日心情
    开心
    2021-3-12 23:18
  • 签到天数: 2 天

    [LV.1]初来乍到

    发表于 2014-10-28 23:58:54 | 显示全部楼层 |阅读模式
    不管执行OUTER JOIN还是INNER JOIN,DBMS总是一次执行两个表的联合,因此为了在单一查询中连接3个或者3个以上的表,就需要进行多次JOIN连接。

    实例 多表连接的综合运用(一)(下载表数据)

         从TEACHER表、STUDENT表和COURSE表中查询所有教师的姓名、所在系、开设的课程名称以及选修这门课程的学生姓名及成绩。并要求显示的教师信息必须是他开设的课程在STUDENT表中有同学选修。

    分析:
        教师姓名、所在系信息是在TEACHER表中存储的,而教师开设的课程名称是在COURSE表中存储的,这里没有要求开设的课程名不能为NULL,所以STUDENT表和COURSE表采用左外连接的方式,而学生姓名和课程成绩信息是在COURSE表中存储的,这里要求教师所开设的课程在STUDENT表中有同学选修,也就是说,学生姓名和课程成绩信息不能为NULL,所以与STUDENT表的连接需要采用内连接。   
      
       
       
         
       

         
       
      
      实例代码: SELECT TNAME, T.DNAME,CNAME,SNAME,MARK  FROM TEACHER AS T  lEFT OUTER JOIN COURSE AS C  ON T.CNO = C.CNO  INNER JOIN STUDENT AS S  ON T. CNO = S. CNO  ORDER BY TNAME

    运行结果如图所示。


    再看看下面命令的结果:


    下面再给出一个UNION集合并运算与多表连接联合使用的实例。
      实例 多表连接的综合运用(二)
        从STUDENT表中查询至少修过“计算机入门”或者“生物工程概论”两门课程中的一门的学生的学号、姓名及所修课程名和课程成绩。

    分析:课程名及课程成绩信息在COURSE表中存储,而学生的学号、姓名信息在STUDENT表中存储,显然需要对二表通过课程号CNO字段进行等值内连接,分别查询满足两门课程之一的信息,而后进行集合并运算即可得到查询结果。

    实例代码: SELECT SNO, SNAME, CNAME,MARK FROM STUDENT AS S  INNER JOIN COURSE AS C ON S.CNO=C.CNO  WHERE
    CNAME = "计算机入门" UNION SELECT SNO, SNAME, CNAME,MARK  FROM STUDENT AS S  INNER JOIN COURSE AS C
    ON S.CNO=C.CNO WHERE CNAME = "生物工程概论" ORDER BY SNO

    运行结果如图所示。

      
      
       
       

         
       

         
       
      
    复制代码

    源码下载:http://file.javaxxz.com/2014/10/28/235853781.zip
    回复

    使用道具 举报

    您需要登录后才可以回帖 登录 | 立即注册

    本版积分规则

    QQ|手机版|Java学习者论坛 ( 声明:本站资料整理自互联网,用于Java学习者交流学习使用,对资料版权不负任何法律责任,若有侵权请及时联系客服屏蔽删除 )

    GMT+8, 2025-2-26 01:21 , Processed in 0.337258 second(s), 34 queries .

    Powered by Discuz! X3.4

    © 2001-2017 Comsenz Inc.

    快速回复 返回顶部 返回列表