inner join、left join、rigint join 的区别

1. 表

1.1 学生表user

idname
1小赵
2小钱
3小孙

1.2 成绩表grade

没有3号的成绩却多了6号的成绩

idsubjectgradeuid
1语文801
2数学852
3英语992
4语文546

2. JOIN

2.1 inner join

2.1.1 sql:

SELECT
	u.id,
	u.`name`,
	g.`subject`,
	g.`grade` 
FROM
	`user` AS u
	INNER JOIN grade AS g ON u.id = g.uid

2.1.2 结果

idnamesubjectgrade
1小赵语文80
2小钱语文85
2小钱语文99

2.1.3 结论

在表中存在至少一个匹配时,INNER JOIN 关键字返回行。
会返回两个表的交集,只在一个表中有的记录不会被返回。

2.2 left join

2.2.1 sql

SELECT
	u.id,
	u.`name`,
	g.`subject`,
	g.`grade` 
FROM
	`user` AS u
	LEFT JOIN grade AS g ON u.id = g.uid

2.2.2结果

idnamesubjectgrade
1小赵语文80
2小钱语文85
2小钱语文99
3小孙(Null)(Null)

2.2.3 结论

会从左表 (user) 那里返回所有的行,即使在右表 (table_name2) 中没有匹配的行。

2.3 right join

2.3.1 sql

SELECT
	u.id,
	u.`name`,
	g.`subject`,
	g.`grade` 
FROM
	`user` AS u
	RIGHT JOIN grade AS g ON u.id = g.uid

2.3.2 结果

idnamesubjectgrade
1小赵语文80
2小钱语文85
2小钱语文99
(Null)(Null)语文54

2.2.3 结论

会从右表 (grade ) 那里返回所有的行,即使在左表 (table_name1) 中没有匹配的行。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值