当前位置:网站首页>sql 语法中 join 的所有用法总结(简单例子)
sql 语法中 join 的所有用法总结(简单例子)
2022-07-22 09:21:00 【单手入天象】
join 常见的用法有:
目录
full join(full outer join 、outer join)
说明:left join 就是 left outer join、 right join 就是 right outer join、 join 就是 inner join 、full join 就是 full outer join 或者 outer join,他们就是简写而已!
下面来个简单的例子,让我们理解下他们分别是什么样的。
先建两个非常简单的表 table_a 、table_b ,表结构如下:
后面连接用的字段是 aId 和 bId ,他们有4行是有相同的值的,然后每个表有一行是不同的
left join(left outer join)
左连接,表 table_a 左连接表 table_b ,表示以表 table_a 为主,关联上表 table_b 的数据,查出来的结果显示左边的所有数据,然后右边显示的是和左边有交集部分的数据,其余没有的为null
select * from table_a a left join table_b b on a.aId = b.bId;
语句查询结果如下:
right join(right outer join)
右连接,表 table_a 右连接表 table_b ,表示以表 table_b 为主,关联查询表 table_a 的数据,查出来的结果显示右边的所有数据,然后左边显示的是和右边有交集部分的数据,其余没有的为null
select * from table_a a right join table_b b on a.aId = b.bId;
语句查询结果如下:
join(inner join)
内连接,表示以两个表的交集为主,查出来是两个表有交集的部分,其余没有关联(on 条件不满足)就不显示出来
select * from table_a a inner join table_b b on a.aId = b.bId;
语句查询结果如下:
full join(full outer join 、outer join)
外连接,就是求两个表集合的并集。从笛卡尔积的角度讲就是从笛卡尔积中挑出ON子句条件成立的记录,然后加上左表中剩余的记录,最后加上右表中剩余的记录
mySql 不支持 full join ,下面语句在 mySql 下会运行报错!
select * from table_a a full join table_b b on a.aId = b.bId;
因为外连接,他还有一种概念的说法是:left join 和 right join 的结果加起来再去重
所以可以用 union 连接 left join 和 right join 的结果来替换 outer join
(注意是 union,不是 union all)
select * from table_a a left join table_b b on a.aId = b.bId
union
select * from table_a a right join table_b b on a.aId = b.bId;
查询结果如下:
select * from table_a a outer join table_b b on a.aId = b.bId;
cross join
交叉连接,就是得出两个表的笛卡尔积,这个在实际开发中用得很少
注意:cross join 后面是不要加 on 条件的
说明:在 mysql 中,如果你用 cross join 后面跟 on 条件,那他跟 join 的效果是一样的
select * from table_a cross join table_b
查询结果如下:
边栏推荐
- 总结20220215(kruskal和prim)
- PAT乙级1020月饼(注意测点)
- 6-2-深度优先搜索 地下迷宫探索 (30分)
- Go 语言学习:Go 语言之旅(五)
- 03.单一职责原则(Simple Responsibility Pinciple)
- LeetCode 653. 两数之和 IV - 输入 BST
- LeetCode 720. 词典中最长的单词
- Leetcode 105. constructing binary trees from preorder and inorder traversal sequences
- Qt | 模態對話框和非模態對話框 QDialog
- 03. simple responsibility principle
猜你喜欢
NRF24L01 wireless module setting transmit receive mode method
MySQL的语句执行顺序
PTA基础题 7-23 币值转换 (20 分) (属实恶心)
OSI model, tcp/ip model
PTA 6-11 求自定类型元素序列的中位数 (25 分)
1.常量中有换行符Qt5-》vs的解决方案;2.同一份代码Qt和vs共同编译的问题和解决方案
App移動端測試【6】應用程序(apk)包管理與activity
06.里氏替换原则(Liskov Substitution Principle,LSP)
STM32+ESP8266+MQTT协议连接OneNet物联网平台
01. Open closed principle
随机推荐
[Nordic] nrf52810 OTA upgrade (III) – DFU theoretical analysis
App移动端测试【6】应用程序(apk)包管理与activity
Summary 20220213 (Floyd and Dijkstra)
1.QTableWidget插入按钮,灵活删除本行,一列显示行号
Unity:素材下载
Summary 20220121
bjyx
LeetCode 114. 二叉树展开为链表
App mobile terminal test [6] application program (APK) package management and activity
总结20220118(二叉树)
LeetCode: 185. 部门工资前三高的所有员工
03.单一职责原则(Simple Responsibility Pinciple)
Go 语言学习:Go 语言之旅(五)
Add the GD Library under centos7.5, and then the MySQL expansion library. There is no problem without the configuration of MySQL expansion. There is no MySQL expansion in phpinfo
总结20220213(floyd和dijkstra)
[FatFs] FAT32 file system protocol summary (Theory + Practice)
1.QTimer::singleShot如何传参、2.QMetaObject::invokeMethod如何用函数传值
1.mysql null 和 in;2.127.0.0.2是啥?
06.里氏替换原则(Liskov Substitution Principle,LSP)
LeetCode 105. 从前序与中序遍历序列构造二叉树