头歌实训之连接查询

🌟 各位看官好,我是 maomi_9526

🌍 种一棵树最好是十年前,其次是现在!

🚀 今天来学习C语言的相关知识。

👍 如果觉得这篇文章有帮助,欢迎您一键三连,分享给更多人哦

目录

第1关:自然连接

第2关:等值连接

第3关:内连接查询

第4关:自身连接查询

第5关:外连接查询

第1关:自然连接

任务描述

本关任务:使用自然连接求选修了严敏老师的数学分析课程的学生的姓名、课程名称、教师名和成绩。

相关知识

通过 MySql 自己的判断完成连接过程,不需要指定连接条件。MySql 会使用表内的,相同的字段,作为连接条件。

自然连接分为内外之分,内连接有 natural join 和using 字段两种;外连接有左外连接 natural left join、右外连接 natural right join 。

编程要求

根据提示,在右侧编辑器补充代码,使用自然连接求选修了严敏老师的数学分析课程的学生的姓名、课程名称、教师名和成绩。

测试说明

编写代码后,点击测评即可。


开始你的任务吧,祝你成功!

复制代码
 use teachingdb;
 /****请在此编写代码,操作完毕之后点击评测******/
 
 /**********Begin**********/
select sname,cname,tname,grade from  student natural join course natural join teach natural join score where tname='严敏'and cname='数学分析';
  
 /**********End**********/

第2关:等值连接

任务描述

本关任务:使用等值连接求选修数学分析课程的学生的姓名、课程名称和成绩。

相关知识

当连接运算符为等号时为等值连接

编程要求

根据提示,在右侧编辑器补充代码,使用等值连接求选修数学分析课程的学生的姓名、课程名称和成绩。

测试说明

平台会对你编写的代码进行测试。


开始你的任务吧,祝你成功!

复制代码
 use teachingdb;
 /****请在此编写代码,操作完毕之后点击评测******/
 
 /**********Begin**********/
  
  select sname,cname,grade from student natural join course natural join score where cname='数学分析';
 /**********End**********/

第3关:内连接查询

任务描述

本关任务:使用 JOIN 连接求选修了课程的学生的学号和姓名。

相关知识

取得两个表中存在连接匹配关系的记录。

语法如下:

select * from A inner join B on A.name = B.name;

编程要求

根据提示,在右侧编辑器补充代码,使用 JOIN 连接求选修了课程的学生的学号和姓名。

测试说明

平台会对你编写的代码进行测试:


开始你的任务吧,祝你成功!

复制代码
 use teachingdb;
 /****请在此编写代码,操作完毕之后点击评测******/
 
 /**********Begin**********/
   select distinct student.sno,student.sname from score inner join student  on student.sno=score.sno;
  
 /**********End**********/

第4关:自身连接查询

任务描述

本关任务:使用自身连接查询求年龄大于'刘东明' 的所有学生的姓名与出生日期。

相关知识

为了完成本关任务,你需要掌握如何使用自连接。

自连接

MySQL 自连接操作,没有特定的关键字,所谓自连接指的是同一个表不同实例之间的 join 操作。

特征:

  • 自连接是同一个表不同实例的连接操作;
  • 自连接必须指定别名区分不同实例。

编程要求

在右侧编辑器补充代码,使用自身连接查询求年龄大于'刘东明' 的所有学生的姓名与出生日期。

测试说明

平台会对你编写的代码进行测试。


开始你的任务吧,祝你成功!

复制代码
 use teachingdb;
 /****请在此编写代码,操作完毕之后点击评测******/
 
 /**********Begin**********/
  select s1.sname ,s1.birthday from student s1 inner join student s2 on s2.sname='刘东明' where s1.birthday<s2.birthday;
  
 /**********End**********/

第5关:外连接查询

任务描述

本关任务:使用外部连接查询求未选修任何课程的学生的学号和姓名。

相关知识

为了完成本关任务,你需要掌握:

1.什么是外连接查询;

2.如何使用外连接查询。

外连接查询

  • 以某张表为主,取出里面的所有记录,然后每条与另外一张表进行连接,不管能不能匹配上条件,最终都会保留。能匹配,正确保留;不能匹配,其它表的字段都置空(null),称为外连接。
  • 外连接查询分为左外连接查询和右外连接查询;
  • 关键字:left/right/full [outer] join ... on。

编程要求

在右侧编辑器补充代码,使用外部连接查询求未选修任何课程的学生的学号和姓名。

测试说明

编写代码后,点击测评即可。


开始你的任务吧,祝你成功!

复制代码
 use teachingdb;
 /****请在此编写代码,操作完毕之后点击评测******/
 
 /**********Begin**********/
  select student.sno,sname from student left join score on score.sno=student.sno where score.cno is null;
  
 /**********End**********/
相关推荐
科技小花2 小时前
数据治理平台架构演进观察:AI原生设计如何重构企业数据管理范式
数据库·重构·架构·数据治理·ai-native·ai原生
一江寒逸3 小时前
零基础从入门到精通MySQL(中篇):进阶篇——吃透多表查询、事务核心与高级特性,搞定复杂业务SQL
数据库·sql·mysql
D4c-lovetrain3 小时前
linux个人心得22 (mysql)
数据库·mysql
阿里小阿希3 小时前
CentOS7 PostgreSQL 9.2 升级到 15 完整教程
数据库·postgresql
荒川之神3 小时前
Oracle 数据仓库雪花模型设计(完整实战方案)
数据库·数据仓库·oracle
做个文艺程序员3 小时前
MySQL安全加固十大硬核操作
数据库·mysql·安全
不吃香菜学java4 小时前
Redis简单应用
数据库·spring boot·tomcat·maven
一个天蝎座 白勺 程序猿4 小时前
Apache IoTDB(15):IoTDB查询写回(INTO子句)深度解析——从语法到实战的ETL全链路指南
数据库·apache·etl·iotdb
不知名的老吴4 小时前
Redis的延迟瓶颈:TCP栈开销无法避免
数据库·redis·缓存
YOU OU4 小时前
三大范式和E-R图
数据库