美文网首页
【SQL】(十三):创建高级联结

【SQL】(十三):创建高级联结

作者: Lottie2017 | 来源:发表于2020-07-15 11:52 被阅读0次

    本系列为自己学习时的笔记及心得体会,转载请注明出处。

    1、给表起别名

    无需多说,给个例子:

    2、使用不同类型的联结

    ①自联结(self-join)

    需求:要给与Jim Jones同一公司的所有顾客发送一封邮件

    实现:先要找到Jim Jones所在公司,再找到该公司下的所有顾客,SQL如下图:

    这里可以改为使用自联结,如下:

    自联结通常作为外部语句,用来替代从相同表中检索数据的使用子查询语句。虽然最终结果是相同的,但很多DBMS处理联结比处理子查询要快得多。

    ②自然联结(natural join)

    自然联结要求你只能选择那些唯一的列。一般通过对一个表使用通配符*,而对其他表的列使用明确的子集来完成。

    事实上我们建立的内联结都是自然联结。

    ③外联结(outer join)

    如果联结需要包含在相关表中没有关联行的行,我们用外联结。

    如:要检索包括没有订单顾客在内的所有顾客,输入和输出如下:

    外联结:LEFT OUTER JOIN

    如果此时用内联结,输入输出如下,可看到,内联结不会把没有订单的客户检索出来。

    内联结

    注意:在使用OUTER JOIN的语法时,必须使用RIGHT或LEFT关键字指定包括其所有行的表。(RIGHT指出的是OUTER JOIN右边的表,而LEFT指出的是OUTER JOIN左边的表。)上面的例子使用LEFTOUTER JOIN 从FROM子句左边的表中选择所有行。

    如果使用RIGHT OUTER JOIN,结果如下:

    RIGHT OUTER JOIN

    3、使用带聚集函数的联结

    需求:检索所有顾客及每个顾客所下的订单数

    操作:输入输出如下,如果换成INNER JOIN,结果略有不同(结果的第2行没有)。

    4、使用联结和联结条件

    总结:

    △ 一般用内联结,但使用外联结也有效

    △ 使用联结时要提供联结条件

    △ 在一个联结中可包含多个表,甚至可对每个联结采用不同联结类型。

    相关文章

      网友评论

          本文标题:【SQL】(十三):创建高级联结

          本文链接:https://www.haomeiwen.com/subject/tmlfhktx.html