必威体育Betway必威体育官网
当前位置:首页 > IT技术

sql inner join的本质并非是取交集, 而是(可带条件地)膨胀/扩张

时间:2019-09-03 13:40:00来源:IT技术作者:seo实验室小编阅读:81次「手机版」
 

innerjoin

先看看两张表:

mysql> select * from black1;
+----------+
| id       |
+----------+
| zhangsan |
| lisi     |
| wangwu   |
+----------+
3 rows in set (0.00 sec)
mysql> select * from black2;
+----------+
| id       |
+----------+
| zhangsan |
| lisi     |
| wangwu   |
| zhaoliu  |
+----------+
4 rows in set (0.00 sec)

看下inner join的结果:

mysql> select * from (black1 inner join black2);
+----------+----------+
| id       | id       |
+----------+----------+
| zhangsan | zhangsan |
| lisi     | zhangsan |
| wangwu   | zhangsan |
| zhangsan | lisi     |
| lisi     | lisi     |
| wangwu   | lisi     |
| zhangsan | wangwu   |
| lisi     | wangwu   |
| wangwu   | wangwu   |
| zhangsan | zhaoliu  |
| lisi     | zhaoliu  |
| wangwu   | zhaoliu  |
+----------+----------+
12 rows in set (0.00 sec)

其实, 上述括号是可以去掉的, 因为优先级本来就如此:

mysql> select * from black1 inner join black2;
+----------+----------+
| id       | id       |
+----------+----------+
| zhangsan | zhangsan |
| lisi     | zhangsan |
| wangwu   | zhangsan |
| zhangsan | lisi     |
| lisi     | lisi     |
| wangwu   | lisi     |
| zhangsan | wangwu   |
| lisi     | wangwu   |
| wangwu   | wangwu   |
| zhangsan | zhaoliu  |
| lisi     | zhaoliu  |
| wangwu   | zhaoliu  |
+----------+----------+
12 rows in set (0.00 sec)

可见, inner  join就是表的膨胀/扩张。

但是, 很多资料描述, inner join是两个圆的交集, 这是怎么回事呢? 来看看(如下括号也可以去掉):

mysql> select * from (black1 inner join black2 on black1.id=black2.id);
+----------+----------+
| id       | id       |
+----------+----------+
| zhangsan | zhangsan |
| lisi     | lisi     |
| wangwu   | wangwu   |
+----------+----------+
3 rows in set (0.00 sec)

可见, 通过增加条件, 可以限制膨胀/扩张。

为了方便起见, 可以对表进行临时重命名, 如下:

mysql> select * from black1 b1 inner join black2 b2 on b1.id=b2.id;
+----------+----------+
| id       | id       |
+----------+----------+
| zhangsan | zhangsan |
| lisi     | lisi     |
| wangwu   | wangwu   |
+----------+----------+
3 rows in set (0.00 sec)

如果只想展示black1的列, 就这样来:

mysql> select id from black1 b1 inner join black2 b2 on b1.id=b2.id;
ERROR 1052 (23000): Column 'id' in field list is ambiguous
mysql> 

为什么错误呢? 因为需要指明是哪个表的id, 如下:

mysql> select b1.id from black1 b1 inner join black2 b2 on b1.id=b2.id;
+----------+
| id       |
+----------+
| zhangsan |
| lisi     |
| wangwu   |
+----------+
3 rows in set (0.00 sec)

可见, inner join的本质并不是取交集, 而是膨胀/扩张。 只不过, 通过有条件的膨胀/扩张, 间接可以实现取交集的目的。在实际应用中, 往往是用inner join来实现取交集, 很常用。

最后, 我们再来强调, inner join是膨胀/扩张, 是可带条件的膨胀/扩张(实现交集):

mysql> select * from black1;
+----------+
| id       |
+----------+
| zhangsan |
| zhangsan |
| zhangsan |
+----------+
3 rows in set (0.00 sec)

mysql> select * from black2;
+----------+
| id       |
+----------+
| zhangsan |
| zhangsan |
| zhangsan |
| zhangsan |
+----------+
4 rows in set (0.00 sec)

mysql> select * from black1 b1 inner join black2 b2 on b1.id=b2.id;
+----------+----------+
| id       | id       |
+----------+----------+
| zhangsan | zhangsan |
| zhangsan | zhangsan |
| zhangsan | zhangsan |
| zhangsan | zhangsan |
| zhangsan | zhangsan |
| zhangsan | zhangsan |
| zhangsan | zhangsan |
| zhangsan | zhangsan |
| zhangsan | zhangsan |
| zhangsan | zhangsan |
| zhangsan | zhangsan |
| zhangsan | zhangsan |
+----------+----------+
12 rows in set (0.00 sec)

mysql> 

相关阅读

记住left join最简单的方式

参考https://zhidao.baidu.com/question/13636248.html 简单粗暴如下: 表aaid adate1    a12    a23    a3表bbid bdate1

Thread.join()

线程A的run方法中调用了线程B的join,此时线程A处于阻塞状态,直到线程B执行完毕或者死亡的时候,线程A才会继续执行。

JS中的innerHTML,innerText,value的区别

一、区别 innerHTML 在控件中加html代码 ,就是设置一个元素里面的HTML,标签对文本信息有效。 innerTEXT 打印标签之间的纯文本

innerHTML的基本用法

定义:innerHTML 属性设置或返回表格行的开始和结束标签之间的 HTML。 /*这串代码的var a的变量是我瞎写的。我忘记js咋样定义变量

Adjoin the Networks Gym - 100781A

http://codeforces.com/gym/100781/attachments 给出一个森林 问将图连通后最小的树直径 对于所有连通块都求出直径 若只有一个连

分享到:

栏目导航

推荐阅读

热门阅读