快捷搜索:

深入理解mysql之left join 使用详解

深入理解mysql之leftjoin使用详解

  ON 条件(“A LEFT JOIN B ON 条件表达式”中的ON)用来决定如何从 B 表中检索数据行。

  如果 B 表中没有任何一行数据匹配 ON 的条件,将会额外生成一行所有列为 NULL 的数据

  在匹配阶段 WHERE 子句的条件都不会被使用。仅在匹配阶段完成以后,WHERE 子句条件才会被使用。它将从匹配阶段产生的数据中检索过滤。

  第二条查询做了简单的LEFT JOIN,然后使用 WHERE 子句从 LEFT JOIN的数据中过滤掉不符合条件的数据行。

  如前所述,WHERE 条件查询发生在 匹配阶段之后,这意味着 WHERE ... IS NULL 子句将从匹配阶段后的数据中过滤掉不满足匹配条件的数据行。

  就像在C语言中的逻辑 AND 和 逻辑 OR表达式一样asp源码下载网站,其操作数是从左到右求值的。如果第一个参数做够判断操作结果,那么第二个参数便不会被计算求值(短路效果)

  如果你吧基本的查询条件放在 ON 子句中,把剩下的否定条件放在 WHERE 子句中asp技术,那么你会获得相同的结果。

  如果你只需要第一个表中的数据的话,这些查询会返回相同的结果集。有一种情况就是asp技术,如果你从 LEFT JOIN的表中检索数据时,查询的结果就不同了。

  如果你使用 LEFT JOIN 来寻找在一些表中不存在的记录,你需要做下面的测试:WHERE 部分的 col_name IS NULL(其中 col_name 列被定义为 NOT NULL),MYSQL 在查询到一条匹配 LEFT JOIN 条件后将停止搜索更多行(在一个特定的组合键下)。

您可能还会对下面的文章感兴趣: