zoukankan      html  css  js  c++  java
  • sql用逗号连接多张表对应哪个join?

    转自:http://blog.csdn.net/huanghanqian/article/details/52847835

    四种join的区别已老生常谈:

    • INNER JOIN(也可简写为JOIN): 如果表中有至少一个匹配,则返回行
    • LEFT JOIN: 即使右表中没有匹配,也从左表返回所有的行
    • RIGHT JOIN: 即使左表中没有匹配,也从右表返回所有的行
    • FULL JOIN: 只要其中一个表中存在匹配,就返回行

    那么问题来了,还有一种常见的写法是将表用逗号隔开,那这个又是怎么连接的呢。

    先看这两张表。

    使用逗号隔开的方法来连接表:

    SELECT *  
    FROM   employeedepartment 
    WHERE  employee.DepartmentID = department.DepartmentID

    输出结果:

    可以很明显发现:这不就是inner join嘛!

    没错,答案正是这样:sql用逗号连接多张表对应的是 inner join。

    为了严谨性,我到处找sql的官方文档来证实这一点。然而搜不出来sql的文档(谁知道网址请务必发我),最后还是在维基百科上找到了可以当作论据的话。

    SQL 定义了两种不同语法方式去表示"连接"。首先是"显式连接符号",它显式地使用关键字 JOIN,其次是"隐式连接符号",它使用所谓的"隐式连接符号"。隐式连接符号把需要连接的表放到 SELECT 语句的 FROM 部分,并用逗号隔开。这样就构成了一个"交叉连接",WHERE 语句可能放置一些过滤谓词(过滤条件)。那些过滤谓词在功能上等价于显式连接符号. SQL 89标准只支持内部连接与交叉连接,因此只有隐式连接这种表达方式;SQL 92标准增加了对外部连接的支持,这才有了JOIN表达式。

    也就是说,

    SELECT *
    FROM   employee 
           INNER JOIN department 
              ON employee.DepartmentID = department.DepartmentID
    

    等价于:

    SELECT *  
    FROM   employeedepartment 
    WHERE  employee.DepartmentID = department.DepartmentID

    至于哪个效率高一点,其实两者是一回事,没有区别。只是内连接是由SQL 1999规则定的书写方式而已。

    另外,在写sql语句测试4种join的时候,发现mysql对于full join返回的结果和inner join一模一样。经查阅资料,才发现原来mysql不支持full join啊。

    见:http://stackoverflow.com/questions/4796872/full-outer-join-in-mysql

    参考资料:

    1.维基百科 https://zh.wikipedia.org/wiki/%E8%BF%9E%E6%8E%A5_(SQL)

    2.w3school http://www.w3school.com.cn/sql/sql_join.asp

    3.CSDN博客最后一段话 http://www.cnblogs.com/huangfr/archive/2012/06/20/2555530.html

  • 相关阅读:
    SharePoint 2010学习笔记之一:创建”最新动态”WebPart
    IE6 Png 图片透明
    C# Url 过滤特殊字符
    委托的几个实例用法
    MVC中Code First编程一些小技巧
    Javascript 学习
    NET下XML的读写操作
    C#位运算讲解与示例[转]
    DB2导入导出命令(工作中使用)
    上海长期招聘c#/c++软件工程师
  • 原文地址:https://www.cnblogs.com/gmq-sh/p/7581150.html
Copyright © 2011-2022 走看看