mysql - SQL 这个 left jion 和 left outer jion 怎么结果是一样的?
问题描述
SELECT b.id,b.cid,b.name,t.type FROM shbooks b LEFT JOIN shtype t ON t.id = b.cid;SELECT b.id,b.cid,b.name,t.type FROM shbooks b LEFT OUTER JOIN shtype t ON t.id = b.cid;
不加OUTER的时候,我完全能理解,把表1在表2对应的类名显示出来,
但是加上 OUTER后,我看到结果还是一模一样,用什么例子可以理解加和不加的区别呢?
问题解答
回答1:LEFT JOIN和LEFT OUTER JOIN是一样的,只是通常我们写SQL语句的是时候把OUTER给省略了。这个可以理解像内连接,我们写内连接的时候,通常也是省略INNER,直接写JOIN
多表链接有
内连接(JOIN 或 INNER JOIN)
SELECT * FROM a [INNER] JOIN b ON a.id=b.id
外连接
左连接或者叫左外向连接(LEFT JOIN 或者 LEFT OUTER JOIN)
SELECT * FROM a LEFT [OUTER] JOIN b ON a.id=b.id
右连接或者叫右外向连接(RIGHT JOIN 或者 RIGHT OUTER JOIN)
SELECT * FROM a RIGHT [OUTER] JOIN b ON a.id=b.id
完全外连接,就是通过关键UNION把左连接和右连接两个语句连在一起
SELECT * FROM a LEFT [OUTER] JOIN b ON a.id=b.idUNIONSELECT * FROM a RIGHT [OUTER] JOIN b ON a.id=b.id
交叉连接(CROSS JOIN),这个会涉及到笛卡尔积,笛卡尔积我个人理解就是两个表交叉组合。所以得到的集合结果就是查询到的A表符合条件的记录*B表符合条件的记录.
这个有个小坑,就是不能像内连接和外连接一样,给语句加上ON,如果加了,查询结果就像内连接一样
SELECT * FROM a CROSS JOIN b where a.id=1回答2:
这两个应该就是一样的吧。left join是left outer join的简写。你可以用explain extended和show warnings看到数据库优化改写之后的语句,两个SQL是一样的。
相关文章:
1. javascript - jQuery each 方法第三个参数args 如何解释?2. java - 阿里的开发手册中为什么禁用map来作为查询的接受类?3. ubuntu apt-get install update 无法更新4. apache - 想把之前写的单机版 windows 软件改成网络版,让每个用户可以注册并登录。类似 qq 的登陆,怎么架设服务器呢?5. java - 关于i++的一个题目6. css3 - Typecho 后台部分表单按钮在 Chrome 下出现灵异动画问题,求解决7. javascript - 为什么嵌套的Promise不能按预期捕获Exception?8. webgl - android上类似汽车之家的3d全景照片怎么实现9. python - 为什么写了换行语句,结果还是没有换行?10. 请教MVC分发控制器时的相关内容
