mysql数据库关联关键字join可以使用多次吗?

mysql数据库关联关键字join可以使用多次吗?,第1张

select

b1.username as userNameCome,

b2.username as userNameTo,

a.info

from A a

left join B b1 on a.userIdCome=b1.userId

left join B b2 on a.userIdTo=b2.userId

Mysql连接(join)查询

1、基本概念

将两个表的每一行,以“两两横向对接”的方式,所得到的所有行的结果。

假设:

表A有n1行,m1列;

表B有n2行,m2列;

则表A和表B“对接”之后,就会有:

n1*n2行;

m1+m2列。

2、则他们对接(连接)之后的结果类似这样:

3、连接查询基本形式: from

表1

【连接方式】

join

表2

【on连接条件】连接查询基本形式: from

表1

【连接方式】

join

表2

【on连接条件】

1、连接查询的分类

交叉连接

其实就是两个表之间按连接的基本概念,进行连接之后所得到的“所有数据”,而对此无任何“筛选”的结果——筛选就是指连接条件。

即:交叉连接就是没有条件的“全部连接”——有称为 笛卡尔积。

交叉连接通常没有实用价值,因为这样连接之后 数据,每一行数据的意义就可能会“丢失”。

形式:

from

表1

【cross】

join

表2

或:

from

表1

表2

内连接

形式:

from

表1

【inner】

join

表2

on

表1.字段1

=

表2.字段2;

含义:

取得一个“交叉连接”的结果中,满足所设定的连接条件(就是on后面的条件)的那些行的数据;

交叉连接往往会有“无意义数据”,如下:

2、看内连接的结果:

3、结果为:

4、可见:内连接其实就是找出一个交叉连接的数据结果中,“有意义”的那些数据行。而一个交叉连接,其中的数据,有的有意义,有的没有意义(错误数据)。

但是,要注意:

1,这种连接条件,不是随意设置,而是要根据表之间的实际关系来设置,通常该关系就是两个表之间的具有“主外键关系”的两个字段的值相等。

2,可见,连接查询,跟我们之前所学的“外键关系”,是有其内在的逻辑一致性的。

3,不过,我们做内连接的时候,并不是要求2个表“必须”有外键关系——我们只是自己从现实角度理解他们有外键关系(数据关系)就可以,而在查询的时候使用内连接就建立起了他们的关系。可见:内连接其实就是找出一个交叉连接的数据结果中,“有意义”的那些数据行。而一个交叉连接,其中的数据,有的有意义,有的没有意义(错误数据)。

您可能感兴趣的文章:MySQL

left

join *** 作中on和where放置条件的区别介绍mysql使用from与join两表查询的区别总结mysql多个left

join连接查询用法分析MySQL优化之使用连接(join)代替子查询Mysql中的join *** 作

多表联合查询语句:SELECT * FROM table LEFT JOIN ...ON.... WHERE ...ORDER BY ....LIMIT ....拿laizijiding的例子说明问题:三个表 板块表(block)、帖子表(post)、会员表(user)如果查询 帖子列表中 帖子 是属于哪个板块和添加帖子的会员信息,sql语句如下:SELECT * FROM post LEFT JOIN block ON....LEFT JOIN user ON....WHERE ...ORDER BY ....LIMIT ....(1)这样写是没有问题的,也可以这样写:SELECT * FROM post LEFT JOIN user ON....LEFT JOIN block ON....WHERE ...ORDER BY ....LIMIT ....(2)上面两个到底哪个效率高呢,应该是(1)效率较高,关于连接条件的优化在顺序上有个原则:数剧量少的条件尽量写在前面。一个论坛当中板块的数量要比用户的数量小的多了。


欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/zaji/6141698.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2023-03-16
下一篇 2023-03-16

发表评论

登录后才能评论

评论列表(0条)

保存