好问题
Good  Question
  • 首 页
  • 问题
    • PHP
    • JAVA
    • CPlusPlus
    • C#
    • SQL
  • 关 于
  • 联 系
“INNER JOIN ON”子句对比“WHERE”子句 关闭 返回上一级  

“INNER JOIN ON”子句对比“WHERE”子句
+ 查看更多

发布日期:2018-02-23 09:53
分类:SQL
浏览次数:92
为了简单起见,假设所有相关字段都不为NULL。

你可以这样做:
SELECT
    table1.this, table2.that, table2.somethingelse
FROM
    table1, table2
WHERE
    table1.foreignkey = table2.primarykey
    AND (一些其他条件)
或者这样做:
SELECT
    table1.this, table2.that, table2.somethingelse
FROM
    table1 INNER JOIN table2
    ON table1.foreignkey = table2.primarykey
WHERE
    (一些其他条件)
在MYSQL中这两种方法的工作方式是相同的吗?
 
 
回答:
 
“INNER JOIN”是您应该使用的ANSI语法。
它通常被认为更具可读性,特别是当你加入大量的二维表时。
当需要时它也可以很容易地用“OUTER JOIN”替换。“WHERE”语法更多的是关系模型导向。
两个表使用“JOIN”语句的结果是应用了两个表的笛卡尔乘积并且过滤出具有连接列匹配的那些行。
使用“WHERE”语法更容易看出这一点。
至于你的例子,在MySQL(通常在SQL)中,这两个查询是同义词。
还要注意MySQL也有一个“STRAIGHT_JOIN”子句。
使用此子句,可以控制JOIN的顺序:哪个表在外循环中扫描,哪个表在内循环中。
你不能使用“WHERE”语法在MySQL中控制顺序。
 
上一篇如何在SQL Server中转义一个单引号?
怎么才能把多个元组的数据集中到一个中去?下一篇
下一篇怎么才能把多个元组的数据集中到一个中去?

最新文章

  • 函数`__construct`用来干嘛的
    发布日期:2018-03-26
  • 通过访客的IP得到他们的地区
    发布日期:2018-03-26
  • 合并两个PHP对象的最好的方法是什么?
    发布日期:2018-03-26
  • 该如何把一该如何把一个对象转化成数组?
    发布日期:2018-03-26
  • 什么是输出缓冲区?
    发布日期:2018-03-26
  • 在PHP中怎么把用逗号分隔的字符串分隔在一个数组里?
    发布日期:2018-03-26
  • 在PHP中使用foreach循环时查找数组的最后一个元素
    发布日期:2018-03-26
关于好问
收集整理一些有用的问题和回答,造福中国的程序旺和IT喵们!
友情链接
起飞页 
相关信息
版权声明
Copyright © 2016 - 2022  苏州卡达网络科技有限公司 备案号:苏ICP备09008221号