头歌实训之连接查询

🌟 各位看官好,我是 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**********/
相关推荐
coding-fun25 分钟前
电子发票批量提取导出合并助手
大数据·数据库
leo_23227 分钟前
备份&恢复--SMP(软件制作平台)语言基础知识之三十九
数据库·数据安全·开发工具·smp(软件制作平台)·应用系统
何以不说话30 分钟前
mysql 的主从复制
运维·数据库·学习·mysql
二二牧人30 分钟前
qemu arm64 linux开发环境搭建
linux·运维·数据库
茁壮成长的露露34 分钟前
导出导入工具mongoexport、mongoimport
数据库·mongodb
Coder_Boy_1 小时前
基于SpringAI的在线考试系统-考试系统DDD(领域驱动设计)实现步骤详解
java·数据库·人工智能·spring boot
workflower1 小时前
软件需求规约的质量属性
java·开发语言·数据库·测试用例·需求分析·结对编程
橘子132 小时前
MySQL库的操作(二)
数据库·mysql·oracle
todoitbo2 小时前
多模数据库技术解析:以KingbaseES MongoDB兼容版为例
数据库·mongodb·kingbasees·金仓数据库
正在走向自律2 小时前
ksycopg2实战:Python连接KingbaseES数据库的完整指南
数据库·python·国产数据库·kingbase·kingbasees·数据库平替用金仓·ksycopg2