Mysql的多表查询及表的连接

Mysql的多表查询及表连接

目录

连接查询条件


  • 查询的两张表如果出现同名的列,我们需要将表名标注到列名前面

  • 如果是非同名的列,表名可加可不加 ,推荐加上为了书写方便,**可以给表添加别名,**一般情况下取首字母,特殊情况下取它所代表的含义,表的别名只在本次查询中生效

  • 如果表与表进行关联查询的时候,如果不添加关联条件,查询的总记录数就是a*b = 笛卡尔积,数据匹配不正确

  • 多表查询的时候必须要加条件

    • 等值
    • 非等值

有关联的表的连接


natural join

自动选择列名相同并且类型相同的列

格式:表名 natural join 列名

代码展示:

sql 复制代码
select * from sc natural join student;

运行结果:

using

指定等值连接的列

格式:表名 join 表名 using(同名同类型等值的列名)

代码展示:

sql 复制代码
select * from sc join course using(cno);

运行结果:

on

可以指定两张表关联的条件,可以是非等值 的操作,添加约束

等值连接

表 join 表 on 表.列=表.列

代码展示:

sql 复制代码
select * from course join teacher;
-- on 添加约束
select * from course join teacher on course.tno=teacher.tno;

运行结果:

非等值连接

不使用等于(=)操作符来比较字段,而是可能使用其他比较操作符

  • 格式:表名 join 表名 on 非等值操作

表与表的外连接


左外连接

显示左面表所有的数据

  • 列名 left join 列名 (on 判断)
    代码展示:
sql 复制代码
select * from course left join teacher on course.tno=teacher.tno;

运行结果:

右外连接

显示右面表所有的数据

  • 列名 left join 列名 (on 判断)

代码展示:

sql 复制代码
select * from course right join teacher on course.tno=teacher.tno;

运行结果:

表的自连接


格式:表名 as 表名1 inner join 表名 as 表名2 on 操作

代码展示:

sql 复制代码
select * from student as a inner join student as b  on a.sno=b.sno;

运行结果:

表的子连接


把一个SQL语句的查询结果当成另外一个SQL语句的查询条件

代码展示:

sql 复制代码
select *from sc;
select * from sc where score>(select avg(score) from sc);

运行结果:


表的伪表查询


如果我们所需要的查询条件需要别的SQL语句提供,如果需要多个查询条件,这是就要将所有的查询结果当做伪表进行管理

代码展示:

复制代码
select course.cname,s2.sname from (select sc.cno,s1.sno,s1.sname from (select sno,sname from student) as s1,sc where s1.sno=sc.sno) as s2,course where course.cno=s2.cno;

运行结果:

相关推荐
kylezhao201912 分钟前
C# 中的 SOLID 五大设计原则
开发语言·c#
全栈前端老曹16 分钟前
【MongoDB】Node.js 集成 —— Mongoose ORM、Schema 设计、Model 操作
前端·javascript·数据库·mongodb·node.js·nosql·全栈
神梦流30 分钟前
ops-math 算子库的扩展能力:高精度与复数运算的硬件映射策略
服务器·数据库
让学习成为一种生活方式39 分钟前
trf v4.09.1 安装与使用--生信工具42-version2
数据库
凡人叶枫1 小时前
C++中输入、输出和文件操作详解(Linux实战版)| 从基础到项目落地,避坑指南
linux·服务器·c语言·开发语言·c++
啦啦啦_99991 小时前
Redis-5-doFormatAsync()方法
数据库·redis·c#
生产队队长1 小时前
Redis:Windows环境安装Redis,并将 Redis 进程注册为服务
数据库·redis·缓存
老邓计算机毕设1 小时前
SSM找学互助系统52568(程序+源码+数据库+调试部署+开发环境)带论文文档1万字以上,文末可获取,系统界面在最后面
数据库·ssm 框架·javaweb 毕业设计
春日见1 小时前
车辆动力学:前后轮车轴
java·开发语言·驱动开发·docker·计算机外设
痴儿哈哈1 小时前
自动化机器学习(AutoML)库TPOT使用指南
jvm·数据库·python