MySQL多表连接的入门实例教程

 更新时间:2019年12月25日 08:33:36   作者:EricMa  
这篇文章主要给大家介绍了关于MySQL多表连接的相关资料,文中通过示例代码介绍的非常详细,对大家学习或者使用MySQL具有一定的参考学习价值,需要的朋友们下面来一起学习学习吧

连接可用于查询,更新,建立事实外键(指人为建立的两张表的对应关系,相对的,FORGIEN KEY也称物理外键)

表的连接实质就是外键的逆向约束

连接条件

使用ON设定连接条件,也可以用WHERE代替.

一般情况下

  • ON:设定连接条件
  • WHERE:进行结果集记录的过滤

没有条件的JOIN内连接实质就是笛卡尔积

[INNER] JOIN 内连接

在MySQL中,JOIN, CROSS JOIN 和 INNER JOIN 是等价的。

内连接表示交集,仅显示A、B两表符合连接条件的记录。不符合连接条件的记录不显示。

SELECT goods_id,goods_name,cate_name 
FROM tdb_goods 
INNER JOIN tdb_goods_cate 
ON tdb_goods.cate_id = tdb_goods_cate.cate_id;

使用内连接进行多表更新操作:

--将tdb_goods表中用中文存储的goods_cate修改为tdb_goods_cates表中对应的cate_id,以节省空间
UPDATE tdb_goods 
INNER JOIN tdb_goods_cates
ON goods_cate=cate_name 
SET goods_cate=cate_id;
--tdb_goods 想要更改的表名
--tdb_goods_cates 关联的附表
--goods_cate=cate_name 两个表对应列的关系
--goods_cate=cate_id; 设置 值

外连接

内连接比外连接用的多一些.

若某字段只存在某一表,则另一表的里字段返回 NULL

LEFT [OUTER] JOIN 左外连接

显示左表的全部记录及右表符合连接条件的记录。

  • 如果使用LEFT JOIN,左表中存在一条记录A,在右表中没有找到相应的记录,则返回结果会出现一条只有记录A中的相应字段内容,其他字段都为NULL的记录(RIGHT JOIN类似).

RIGHT [OUTER] JOIN 右外连接

显示右表的全部记录及左表符合连接条件的记录。

多表连接

跟两张表的连接类似

如三张表的连接:

SELECT goods_id,goods_name,b.cate_name,c.brand_name,goods_price
FROM products AS a 
INNER JOIN products_cate AS b 
ON a.goods_cate = b.cate_id
INNER JOIN products_brand AS c 
ON a.brand_name = c.brand_id;

自连接

设计无限分类数据表

在同一张表中既有父类,又有子类,本质上是一棵树:

可以通过对同一张数据表的自身连接来进行查询:

--查找显示父类id对应的名称
SELECT s.type_id,s.type_name,p.type_name AS parent_name
FROM tdb_goods_types AS s 
LEFT JOIN tdb_goods_types AS p 
ON s.parent_id=p.type_id;

--查找子类id对应的名称
SELECT p.type_id,p.type_name,s.type_name AS child_name
FROM tdb_goods_types AS p
LEFT JOIN tdb_goods_types AS s
ON p.type_id=s.parent_id;

--查找有多少子级
SELECT p.type_id,p.type_name,COUNT(s.type_name) AS child_count
FROM tdb_goods_types AS p
LEFT JOIN tdb_goods_types AS s
ON p.type_id=s.parent_id 
GROUP BY p.type_name
ORDER BY p.type_id;

多表查询并删除

这里用自连接模拟两张表,删除该表中的重复项,保留goods_id 较小的记录.

DELETE t1 
FROM tdb_goods AS t1 
LEFT JOIN( --选出goods_name重复的记录
 SELECT goods_id,goods_name 
 FROM tdb_goods 
 GROUP BY goods_name --MySQL 5.7.5以上版本启用了only_full_group_by SQL模式,select的列都要在group中,或者本身是聚合列(SUM,AVG,MAX,MIN)才行,这里没有启用
 HAVING COUNT(goods_name)>=2) 
AS t2 --将t1与t2进行左连接,其实这里内连接和右连接也行
ON t1.goods_name=t2.goods_name --t1和t2的连接条件
WHERE t1.goods_id>t2.goods_id; --在LEFT JOIN结果集中,选出满足t1.goods_id>t2.goods_id的记录

为帮助理解,LEFT JOIN的结果为:

总结

以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作具有一定的参考学习价值,谢谢大家对脚本之家的支持。

相关文章

  • Mysql如何同时交换两个表的表名详解

    Mysql如何同时交换两个表的表名详解

    这篇文章主要给大家介绍了关于Mysql如何同时交换两个表的表名,以及MySQL命令rename修改表名的相关资料,文中通过实例代码介绍的非常详细,需要的朋友可以参考下
    2022-01-01
  • 学习mysql 如何行转列与列传行

    学习mysql 如何行转列与列传行

    这篇文章主要介绍了mysql行转列与列传行的使用方法,帮助大家更好的理解和学习MySQL的使用,语句不难,但有一定的知识参考价值,需要的朋友可以参考一下,希望给你的学习带来帮助
    2022-02-02
  • MySQL生成连续的数字/字符/时间序列的方法

    MySQL生成连续的数字/字符/时间序列的方法

    有时候为了生成测试数据,或者填充查询结果中的数据间隔,需要使用到一个连续的数据序列值,所以,今天我们就来介绍一下如何在 MySQL 中生成连续的数字、字符以及时间序列值,需要的朋友可以参考下
    2024-04-04
  • MySQL存储过程及常用函数代码解析

    MySQL存储过程及常用函数代码解析

    这篇文章主要介绍了MySQL存储过程及常用函数代码解析,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下
    2020-08-08
  • Mysql中使用count加条件统计的实现示例

    Mysql中使用count加条件统计的实现示例

    本文主要介绍了Mysql中使用count加条件统计的实现示例,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2022-07-07
  • MySQL 中查找含有目标字段的表的方法

    MySQL 中查找含有目标字段的表的方法

    这篇文章主要介绍了MySQL 中查找含有目标字段的表的方法,即查找某个字段在哪个表中,这在一些场景中非常有用,需要的朋友可以参考下
    2015-06-06
  • mysql查询时offset过大影响性能的原因和优化详解

    mysql查询时offset过大影响性能的原因和优化详解

    这篇文章主要给大家介绍了关于mysql查询时offset过大影响性能的原因和优化的相关资料,并在文末跟大家分享了MYSQL中limit,offset的区别,需要的朋友可以参考借鉴,下面随着小编来一起学习学习吧
    2018-06-06
  • MySQL多实例配置方案

    MySQL多实例配置方案

    MySQL多实例就是,在一台机器上开启多个不同的服务端口(如:3306,3307,3308...),运行多个MySQL服务进程,这些服务进程通过不同的socket监听不同的端口提供服务。
    2018-04-04
  • MySQL数据中很多换行符和回车符的解决方法

    MySQL数据中很多换行符和回车符的解决方法

    这篇文章主要给大家介绍了关于MySQL数据中很多换行符和回车符的解决方法,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2020-10-10
  • MySQL如何优化查询速度

    MySQL如何优化查询速度

    这篇文章主要介绍了MySQL如何优化查询速度,帮助大家提升自己的数据库性能,感兴趣的朋友可以了解下
    2020-08-08

最新评论