频道栏目
首页 > 数据库 > MySQL > 正文
MySQL多表数据记录查询之内连接的语法说明
2018-05-16 15:37:36      个评论    来源:xiadada2的博客  
收藏   我要投稿

先来看一下,内连接的语法:

SELECTXXXFROMXXXINNERJOINXXXONXXX;

这里INNER可以省略,在上一篇博客中我们对于笛卡尔积现象的研究中,用到的就是内连接,但这并不能说明笛卡尔积算法只是适用于内连接,笛卡尔积算法针对的是表之间数据行的匹配次数,跟内连接还是外连接无关,至于查询结果与你的查询条件有关系,在本文中将对这一算法和内、外连接的区别加以说明。

内连接指的是把表连接时表与表之间匹配的数据行查询出来,就是两张表之间数据行匹配时,要同时满足ON语句后面的条件才行。

左连接和右连接,又叫左外连接和右外连接。

我们来看一下左连接的语法

SELECTXXXFROMXXXLEFT OUTER JOINXXXONXXX

左连接的意思是,无论是否符合ON语句后面的表连接条件都会把左边那张表的记录全部查询出来,右边的那张表只匹配符合条件的数据行。右连接则与之相反(这里同样OUTER可以省略)。

下面我们以左连接为例,来看一下这个匹配的过程。有两张表商品表goods和订单表order_table。

SELECT * FROM goods g LEFT JOIN order_table ot ON g.id = ot.goods_id

\

\

数据行间的匹配以此类推。

最终结果是:

\

蓝线部分表示两张表数据行之间的匹配符合ON g.id= ot.goods_id,虚线则表示不符合匹配条件,我们看到步骤二中,即使左边的表跟右边的表没有一行数据能够匹配的,左边的表的数据行还是会出现在连接之后的临时表中,而这时右边的数据行的内容用Null填充。根据分析我们还可以看到,数据行之间匹配的次数还是符合笛卡尔积。

点击复制链接 与好友分享!回本站首页
上一篇:八种MySQL数据库优化的经典方式
下一篇:Linux下MySQL5.X的修改字符集编码为UTF8(运行字符串函数示例)
相关文章
图文推荐
点击排行

关于我们 | 联系我们 | 广告服务 | 投资合作 | 版权申明 | 在线帮助 | 网站地图 | 作品发布 | Vip技术培训 | 举报中心

版权所有: 红黑联盟--致力于做实用的IT技术学习网站