在MySQL查询中,为什么要使用join而不是在哪里?-问答-阿里云开发者社区-阿里云

开发者社区> 保持可爱mmm> 正文

在MySQL查询中,为什么要使用join而不是在哪里?

2020-05-10 20:23:48 141 1

似乎要合并两个或多个表,我们可以使用join或where。一个相对于另一个的优点是什么?

取消 提交回答
全部回答(1)
  • 保持可爱mmm
    2020-05-10 20:24:05

    任何涉及多个表的查询都需要某种形式的关联,以将结果从表“ A”链接到表“ B”。传统的(ANSI-89)方法是:

    在FROM子句中列出逗号分隔列表中涉及的表 在WHERE子句中编写表之间的关联

    SELECT * FROM TABLE_A a, TABLE_B b WHERE a.id = b.id 这是使用ANSI-92 JOIN语法重写的查询:

    SELECT * FROM TABLE_A a JOIN TABLE_B b ON b.id = a.id 从性能角度来看: 在受支持的地方(Oracle 9i +,PostgreSQL 7.2 +,MySQL 3.23 +,SQL Server 2000+),使用两种语法都不会对性能产生任何好处。优化器将它们视为相同的查询。但是更复杂的查询可以从使用ANSI-92语法中受益:

    控制JOIN顺序的能力-扫描表的顺序 能够在加入表格之前在表格上应用过滤条件 从维护角度: 在ANSI-89上使用ANSI-92 JOIN语法的原因有很多:

    更具可读性,因为JOIN标准与WHERE子句分开 不太可能错过JOIN标准 对除INNER之外的JOIN类型的一致语法支持,使查询易于在其他数据库上使用 WHERE子句仅用作连接表的笛卡尔积的过滤 从设计角度来看: ANSI-92 JOIN语法是模式,而不是反模式:

    查询的目的更加明显;应用程序使用的列很清楚 它遵循关于尽可能使用严​​格类型的模块化规则。显式普遍更好。 结论 缺乏熟悉度和/或舒适度,我认为继续使用ANSI-89 WHERE子句代替ANSI-92 JOIN语法没有任何好处。有人可能会抱怨ANSI-92语法更冗长,但这就是它的明确之处。越明确,就越容易理解和维护。来源:stack overflow

    0 0
相关问答

17

回答

【大咖问答】对话PostgreSQL 中国社区发起人之一,阿里云数据库高级专家 德哥

阿里ACE 彭飞 2019-07-10 09:36:10 965658浏览量 回答数 17

145

回答

【新手入门】云服务器linux使用手册

fanyue88888 2012-11-26 17:14:18 157065浏览量 回答数 145

8

回答

OceanBase 使用动画(持续更新)

mq4096 2019-02-20 17:16:36 333848浏览量 回答数 8

3

回答

请问postgres实时同步数据到mysql数据库有什么好的方案吗?

toni3 2019-06-29 14:55:43 115786浏览量 回答数 3

2

回答

mySQL数据库报错You have an error in your SQL syntax

落地花开啦 2016-02-14 16:09:24 126360浏览量 回答数 2

38

回答

安全组详解,新手必看教程

我的中国 2017-11-30 15:23:46 256856浏览量 回答数 38

249

回答

阿里云LNAMP(Linux + Nginx + Apache + MySQL + PHP)环境一键安装脚本

云代维 2014-02-14 15:26:06 302585浏览量 回答数 249

97

回答

Redhat/CentOS一键安装web环境全攻略

xiaofanqie 2011-08-11 14:51:38 123199浏览量 回答数 97

2

回答

区域选择帮助

fanyue88888 2012-12-07 15:54:30 203996浏览量 回答数 2

11

回答

【精品问答合集】MongoDB热门问答

李博 bluemind 2019-05-29 16:50:19 120861浏览量 回答数 11
66
文章
12595
问答
推荐问答
相关电子书
更多
文娱运维技术
立即下载
《SaaS模式云原生数据仓库应用场景实践》
立即下载
《看见新力量:二》电子书
立即下载