MySQL内连接、外连接、交叉连接
外连接:
左连接:left join 或 left outer join
以左边的表为基准,如果左表有数据,而右表没有数据,左表的数据正常显示,右表数据显示为空。
创建user表,用于记录用户
| user_id | username |
|---|---|
| 1 | 王一 |
| 2 | 李二 |
| 3 | 张三 |
创建log表,用于记录用户的消费情况
| user_id | logging |
|---|---|
| 1 | 100 |
| 2 | 200 |
分析用户的消费情况,每一个用户不一定都有消费,就要用到左连接,把每个用户的消费情况查出来,包括那些没有消费的用户。没有消费的显示为NULL。
select * from user left outer join log on user.user_id=log.user_id;
select * from user left join log on user.user_id=log.user_id;
查询结果:
| user_id | username | user_id1 | logging |
|---|---|---|---|
| 1 | 王一 | 1 | 100 |
| 2 | 李二 | 2 | 200 |
| 3 | 张三 | NULL | NULL |
右连接:right join 或 right outer join
以右边的表为基准,如果右表有数据,而左表没有数据,右表的数据正常显示,左表显示为空,定义完全和左连接相反。
select * from user right join log on user.user_id=log.user_id;
select * from user right outer join log on user.user_id=log.user_id;
查询结果:
| user_id | username | user_id1 | logging |
|---|---|---|---|
| 1 | 王一 | 1 | 100 |
| 2 | 李二 | 2 | 200 |
右表中只有两条数据对应着左表中的两条数据,因为是右连接,以右面的为基础,右面没有的,左面有的就会被舍弃。
全连接:
注:MySQL并不支持full join,不过可以通过union 关键字来合并 left join 与 right join来模拟full join.
创建course表:
| id | course_name | stu_id |
|---|---|---|
| 1 | 数学 | 1 |
| 2 | 语文 | 2 |
| 3 | 英语 | 4 |
| 4 | 生物 | 3 |
创建student表:
| stu_id | stu_name |
|---|---|
| 1 | 王一 |
| 2 | 李二 |
| 3 | 张三 |
| 5 | 李四 |
执行下面语句:
select * from student left join course on student.stu_id=course.stu_id
union
select * from student right join course on student.stu_id=course.stu_id;
查询结果:
| stu_id | stu_name | id | course_name | stu_id1 |
|---|---|---|---|---|
| 1 | 王一 | 1 | 数学 | 1 |
| 2 | 李二 | 2 | 语文 | 2 |
| 3 | 张三 | 4 | 生物 | 3 |
| 5 | 李四 | NULL | NULL | NULL |
| NULL | NULL | 3 | 英语 | 4 |
交叉连接 cross join:
交叉连接得到的是两个表的乘积,也叫笛卡儿积
还是上面的表执行sql语句:
select * from student cross join course;
得到结果如下:
| stu_id | stu_name | id | course_name | stu_id1 |
|---|---|---|---|---|
| 1 | 王一 | 1 | 数学 | 1 |
| 2 | 李二 | 1 | 数学 | 1 |
| 3 | 张三 | 1 | 数学 | 1 |
| 5 | 李四 | 1 | 数学 | 1 |
| 1 | 王一 | 2 | 语文 | 2 |
| 2 | 李二 | 2 | 语文 | 2 |
| 3 | 张三 | 2 | 语文 | 2 |
| 5 | 李四 | 2 | 语文 | 2 |
| 1 | 王一 | 3 | 英语 | 4 |
| 2 | 李二 | 3 | 英语 | 4 |
| 3 | 张三 | 3 | 英语 | 4 |
| 5 | 李四 | 3 | 英语 | 4 |
| 1 | 王一 | 4 | 生物 | 3 |
| 2 | 李二 | 4 | 生物 | 3 |
| 3 | 张三 | 4 | 生物 | 3 |
| 5 | 李四 | 4 | 生物 | 3 |
注:如果不写连接条件,默认也是得到表的笛卡儿积,下面的sql语句中两个表只用了,隔开,得到的结果和上面的一样
select * from student,course;
内连接(等值连接): inner join ,=,>=,<=,<,>
注意内连接不分左表和右表,只是把两个表相对应的数据查出来,自动忽略不对应的数据。
user表,用于记录用户
| user_id | username |
|---|---|
| 1 | 王一 |
| 2 | 李二 |
| 3 | 张三 |
log表,用于记录用户的消费情况
| user_id | logging |
|---|---|
| 1 | 100 |
| 2 | 200 |
执行下面的语句
select * from user inner join log on user.user_id=log.user_id;
select * from user,log where user.user_id=log.user_id;
查询结果:
| user_id | username | user_id1 | logging |
|---|---|---|---|
| 1 | 王一 | 1 | 100 |
| 2 | 李二 | 2 | 200 |
MySQL内连接、外连接、交叉连接的更多相关文章
- mysql数据库中的多表查询(内连接,外连接,子查询)
用两个表(a_table.b_table),关联字段a_table.a_id和b_table.b_id来演示一下MySQL的内连接.外连接( 左(外)连接.右(外)连接.全(外)连接). MySQL版 ...
- mysql 内连接 左连接 右连接 外连接
mysql> desc student;+-------+-------------+------+-----+---------+-------+| Field | Type | Null | ...
- 知识点:Oracle+表连接方式(内连接-外连接-自连接)+详解 来自百度文库
Oracle 表之间的连接分为三种: 1. 内连接(自然连接) 2. 外连接 (1)左外连接 (左边的表不加限制) (2)右外连接(右边的表不加限制) (3)全外连接(左右 ...
- sql内连接外连接自然连接
为什么我们要使用内连接和外连接呢?可以从两张或者多张表中找出,我们需要的属性. 这个比较好:http://www.cnblogs.com/youzhangjin/archive/2009/05/22/ ...
- mysql中的内连接,外连接实例详解
内连接: 只连接匹配的行左外连接: 包含左边表的全部行(不管右边的表中是否存在与它们匹配的行),以及右边表中全部匹配的行右外连接: 包含右边表的全部行(不管左边的表中是否存在与它们匹配的行),以及左边 ...
- SQL中的内连接外连接和交叉连接是什么意思?
内连接又分为等值连接.自然连接和不等连接三种. 外连接分为左外连接(LEFT OUTER JOIN或LEFT JOIN).右外连接(RIGHT OUTER JOIN或RIGHT JOIN)和全外连接( ...
- mysql8必知必会7 连接 内连接 外连接 交叉连接
/* 2 需求:建立产品和分类表 1.查询每种分类的产品数量,没有产品的分类也要统计.(cname,quantity) 2.根据分类名称查询分类中的所有产品 */ -- --------------- ...
- SQL内连接-外连接join,left join,right join,full join
1.创建测试表test1及test2 SQL)); 表已创建. SQL)); 表已创建. ,'name1'); ,'name2'); ,'name3'); ,'name4'); ,'name5'); ...
- 【cl】多表查询(内、外连接)
交叉连接(cross join):该连接产生的结果集笛卡尔积 a有7行,b有8行 a的第一行与b的每一行进行连接,就有8条a得第一行 7*8=56条 select a.real_name,s.u ...
- Oracle内链接+外连接详解
inner join(内连接) 内连接也称为等同连接,返回的结果集是两个表中所有相匹配的数据,而舍弃不匹配的数据.也就是说,在这种查询中,DBMS只返回来自源表中的相关的行,即查询的结果表包含的两源表 ...
随机推荐
- java访问权限表
private(私有的) 默认的(什么都不写) protected(受保护的) public(公共的 ) 同一个类中 yes yes yes yes 同一个包中不同类之间 no yes yes ...
- 矩阵游戏 HYSBZ - 1059(最大流)
1059: [ZJOI2007]矩阵游戏 Time Limit: 10 Sec Memory Limit: 162 MBSubmit: 6266 Solved: 3065[Submit][Stat ...
- KMP模板(KMP)
放一个模板在这里搞事情...... 学KMP的话找SYCstudio吧(博客链接) 代码(多组数据,\(O(n)\)求一个串是否在另一个串里出现过) #include<cstdio> #d ...
- OpenAI 开源机器人模拟 Python 库,并行模拟处理速度提升400%
10000da.cnvboyule.cnjiaeidaypt.cn 在过去一年的研究中,OpenAI团队开源一个使用 MuJoCoengine开发的用于机器人模拟的高性能Python库.雷锋网了解到 ...
- 自学Zabbix之路15.2 Zabbix数据库表结构简单解析-Items表
点击返回:自学Zabbix之路 点击返回:自学Zabbix4.0之路 点击返回:自学zabbix集锦 自学Zabbix之路15.2 Zabbix数据库表结构简单解析-Items表 Items表记录了i ...
- 【转】 cJSON 源码解析
关于cjson的介绍和使用方法就不在这里介绍了,详情请查看上一篇博客cjson使用方法. JSON的内存结构像广义表,可以认为是有层次的双向链表. cJSON程序中的细节点如下: 大量宏替换 大量静态 ...
- POJ3287(BFS水题)
Description Farmer John has been informed of the location of a fugitive cow and wants to catch her i ...
- 端午漫谈(附:Ubuntu18.04下轻量截图软件)
先说声端午快乐- 有空就陪陪家人吧.今天陪外公吃了顿饭,陪老人家聊了会天,颇有点感触.发现技术真的是改变生活,小孩抖音自学跳舞,大人微信刷又刷,很多天海一方的老朋友都可以联系到了... 其实最有感触的 ...
- 斯坦福大学公开课机器学习:Neural network-model representation(神经网络模型及神经单元的理解)
神经网络是在模仿大脑中的神经元或者神经网络时发明的.因此,要解释如何表示模型假设,我们先来看单个神经元在大脑中是什么样的.如下图,我们的大脑中充满了神经元,神经元是大脑中的细胞,其中有两点值得我们注意 ...
- MySQL命令 导出 数据和结构
网上的真是仅供参考,啥也不想说. //先找到mysqldump的目录 //Centos7中位于 /usr/bin 中 然后执行命令: cd /user/bin mysqldump -u [用户名] - ...