MySQL数据库多表查询

1.分类:

           1)一对多    实现:在多的一方建立外键,关联另一方的主键

           2)多对多    实现:建立第三张中间表,至少有两个主键,分别关联两方主键

           3)一对一    实现:任意一方建立外键关联另一方主键,并且设置外键为唯一的(unique)

概述:从多张表中查询数据

笛卡尔积:在多表查询中会出现笛卡尔积的情况,即数学中两个集合,集合A,集合B,组合的所有情况,在多表查询中需要消除这种影响。

具体语法

使用where条件判断可以去除笛卡尔积。

2.  连接查询

  • 内连接:相当于查询A,B交集部分

                查询语法

隐式内连接SELECT  字段列表  from  表1,表2...  WHERE  连接条件
显式内连接SELECT 字段列表 from 表1 INNER JOIN  表2   WHERE  连接条件

                 具体语法:

 

  • 外连接:

                左外连接:查询左表所有数据,及两张表的共有的数据

                右外连接:查询右表所有数据,及两张表的共有的数据

                语法

左外连接SELECT 字段列表  FROM  表1  LEFT [OUTER]  JOIN  表2  ON条件
右外连接SELECT  字段列表  FROM  表1  RIGHT [OUTER]  JOIN  表2  ON条件

                具体语法

 

  • 自连接:查询自身表数据,自连接必须使用表别名

                语法

SELECT 字段列表  FROM 表1 别名1 JOIN  表2 别名2  ON  条件

                具体语法

 3.  联合查询 union/union all

对于union查询,就是把查询的结果合并起来

                 语法

SELECT * FROM ....

UNION ALL

SELECT * FROM ....;

                具体语法

4.子查询

        概念:SQL语句中SELECT语句,称为嵌套查询,又称为子查询

                语法

SELECT * FROM 表1  WHERE  字段列表 = (SELECT .....)

                        注意:子查询的外部语句可以是insert/select/delect/update

  • 根据查询结果不同,分为:
  1. 标量子查询(查询结果为单个值)
  2. 列子查询(查询结果为一列)
  3. 行子查询(查询结果为一行)
  4. 表子查询(查询结果为多行多列)
  • 根据子查询的位置,分为:WHERE 之后,FROM 之后,SELECT 之后

                标量子查询具体语法

                列子查询

                 具体语法

                 行子查询

 

 

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

爱笑的蛐蛐

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值