为了账号安全,请及时绑定邮箱和手机立即绑定

两种sql 写法的区别,进来看看!

两种sql 写法的区别,进来看看!

跃然一笑 2018-12-07 00:08:40
1 SELECT test_A.Id,test_B.Name FROM test_A LEFT JOIN test_B ON test_B.AId = test_A.Id WHERE test_A.Id = 32 SELECT Id,(SELECT NAME FROM test_B WHERE test_A.Id = test_B.AId) Name FROM test_A WHERE test_A.Id = 3上面两种写法在联表方式上有区别吗? 还是两种写法一个意思?
查看完整描述

13 回答

?
德玛西亚99

TA贡献1770条经验 获得超3个赞

得出的结果应该是一样的,但是第二种性能差些,相当于test_a有几条数据都会去test_b表中查询一次,有N条就会查询N次。

查看完整回答
反对 回复 2019-01-07
?
慕容3067478

TA贡献1773条经验 获得超3个赞

建议看一下执行计划

查看完整回答
反对 回复 2019-01-07
?
大话西游666

TA贡献1817条经验 获得超14个赞

一样,但建议用上面left join的写法

查看完整回答
反对 回复 2019-01-07
?
HUWWW

TA贡献1874条经验 获得超12个赞

感觉第二种写法比较怪,不易读;效率上也可能比第一种低,你可以执行试试。

查看完整回答
反对 回复 2019-01-07
?
喵喵时光机

TA贡献1846条经验 获得超7个赞

用 explain 测试一下性能!

查看完整回答
反对 回复 2019-01-07
?
蓝山帝景

TA贡献1843条经验 获得超7个赞

两者效果是一样的

联表跟内联查询其实很多时候可以实现等同的效果

至于性能的话,这个只能自己测试才知道 有些时候联表快 有些时候内联快

 

但可读性来说明显left join(联表)的可读性好点

查看完整回答
反对 回复 2019-01-07
?
慕婉清6462132

TA贡献1804条经验 获得超2个赞

第二种没用过

查看完整回答
反对 回复 2019-01-07
?
慕雪6442864

TA贡献1812条经验 获得超5个赞

感觉第二种效果好一点儿。

查看完整回答
反对 回复 2019-01-07
?
一只甜甜圈

TA贡献1836条经验 获得超5个赞

有区别 ,如果test_a 对应在test_b表中有两条数据,第一种的结果就是两条数据,第二种就报错。性能上,数据量少,没什么区别。

查看完整回答
反对 回复 2019-01-07
?
一只萌萌小番薯

TA贡献1795条经验 获得超7个赞

数据量大呢

查看完整回答
反对 回复 2019-01-07
?
杨魅力

TA贡献1811条经验 获得超6个赞

@koi: 数据量大的话 连接查询性能优于子查询。

查看完整回答
反对 回复 2019-01-07
?
LEATH

TA贡献1936条经验 获得超7个赞

结果是一样的,建议使用第一种写法,第一种写法即使数据库中存在多条数据,他也能正常查询,但第二种就会报错!并且在性能上第一条比较好些

查看完整回答
反对 回复 2019-01-07
?
倚天杖

TA贡献1828条经验 获得超3个赞

第一个是联合查询,left join 以左边的表 test_A为 主表,让符合on条件的右边表test_B 附加上来(总条数恒为左表test_A)

第二个是子查询,就是把某个查询条件或者查询表用sql语句的返回结果代替。

个人建议使用联合查询。执行速度应该更快

查看完整回答
反对 回复 2019-01-07
  • 13 回答
  • 0 关注
  • 764 浏览
慕课专栏
更多

添加回答

举报

0/150
提交
取消
微信客服

购课补贴
联系客服咨询优惠详情

帮助反馈 APP下载

慕课网APP
您的移动学习伙伴

公众号

扫描二维码
关注慕课网微信公众号