当前位置: 首页 > 面试题库 >

MySQL JOIN按什么顺序进行评估?

邢凯歌
2023-03-14
问题内容

我有以下查询:

SELECT c.*
FROM companies AS c
JOIN users AS u USING(companyid)
JOIN jobs AS j USING(userid)
JOIN useraccounts AS us USING(userid)
WHERE j.jobid = 123;

我有以下问题:

  1. USING语法与ON语法同义吗?
  2. 这些联接是从左到右评估的吗?换句话说,此查询是否说:x =公司加入了用户;y = x JOIN工作;z = y加入用户帐户;
  3. 如果对问题2的回答为“是”,那么可以安全地假设“公司”表中包含“公司ID”,“用户ID”和“工作ID”列?
  4. 我不明白在引用别名“ j”时,如何使用WHERE子句来选择公司表上的行

任何帮助,将不胜感激!


问题答案:
  1. USING(字段名)是表示table1.fieldname = table2.fieldname的简写方式。

  2. SQL并未定义完成JOINS的“顺序”,因为这不是语言的本质。显然,必须在语句中指定一个顺序,但是INNER JOIN可以被认为是可交换的:您可以按任何顺序列出它们,您将获得相同的结果。

就是说,当构造一个SELECT … JOIN时,尤其是包括LEFT
JOIN的一个,我发现将第三个JOIN视为将新表与第一个JOIN的结果联接在一起,将第四个JOIN视为对联接的联接是有意义的。第二个JOIN的结果,依此类推。

由于它影响启发式的方式,指定顺序可能会影响查询优化器的行为。

  1. 否。查询的组装方式要求公司和用户都具有公司ID,Jobs具有用户ID和JobID,而useraccounts具有用户ID。但是,只有公司 用户之一需要用户名才能使JOIN起作用。

  2. WHERE子句使用jobs表提供的列来过滤整个结果,即所有JOINed列。



 类似资料:
  • 问题内容: 我正在阅读一本关于线程/同步的简单示例,该书声称使用会允许在同一实例上调用一个线程来访问该方法。它确实按照承诺进行了序列化,但似乎在 下面的方法中创建的第三个数组的大约9/10倍于第二个数组。该代码是示例代码,显示了没有同步方法的问题。 这本书说明了两种方式来处理这个问题,他们是- 并且 很显然,这两种选择工作,因为,相对于原来的代码,括号内的字都像一致… [您好] [世界](大约90

  • 问题内容: 我担心给出的文件和目录的顺序。如果我有这些目录,,,,,,,,,,,,,什么是输出列表的顺序? 它是按数值排序的吗? 或按ASCII值排序,如? 此外,如何获得特定的排序? 问题答案: 用途。这是的文档字符串: listdir(路径)-> list_of_strings 返回一个列表,其中包含目录中条目的名称。 该列表按任意顺序排列 。它不包括特殊条目“。” 和“ ..”,即使它们存在

  • 问题内容: 我正在阅读一些Java文本,并获得以下代码: 在本文中,作者没有给出明确的解释,最后一行的效果是: ; 我不确定自己是否理解:评估是如何发生的? 问题答案: 让我说得很清楚,因为人们一直误会这一点: 子表达式的求值顺序与关联性和优先级无关。结合性和优先级确定以什么顺序运营商执行,但不以什么顺序确定的子表达式进行评估。你的问题与子表达式的计算顺序有关。 考虑一下。乘法比加法具有更高的优先

  • 问题内容: 我想以这种方式进行Ajax调用的堆栈:call(n-1)完成后,call(n)开始… 由于多种原因,我无法使用 async:false : 一些请求可能是 jsonp (最相关) 我还有其他一些可能同时起作用的ajax请求。 浏览器被阻止 我无法以这种方式链接我的请求: 因为请求的数量和参数是根据用户输入动态创建的。 一个小例子说明了我的问题。 您将看到服务器响应顺序是随机的,我要实现

  • 通常,您可以有多个进程,但有时在某些操作中,我们需要确保在执行前一个进程之后执行一个进程。 我们如何在卡蒙达实现它?试图找到类似进程依赖关系的东西(因此进程在上一个进程完成后才开始),但找不到任何东西:( 我考虑在process中添加一些变量(比如),并检查指定的process是否已经完成,但也许会有更好的解决方案。

  • 问题内容: 因此,在数据库中,我存储了乐器名称(以及其他各种属性)。假设它是主键,并且是唯一键。 在PHP脚本中,我按其乐器类选择项,如下所示: 结果表: 这使我可以仅通过查询“萨克斯管”来选择整个乐器系列,例如“高音萨克斯管”,“中音萨克斯管”等。 在该特定示例中,结果按其ID排序(您可以假定其为auto_incremented)。更理想的是按字母顺序排序,是吗? 这工作正常,但作为音乐人,他们