本系列为自己学习时的笔记及心得体会,转载请注明出处。
1、给表起别名
无需多说,给个例子:
2、使用不同类型的联结
①自联结(self-join)
需求:要给与Jim Jones同一公司的所有顾客发送一封邮件
实现:先要找到Jim Jones所在公司,再找到该公司下的所有顾客,SQL如下图:
这里可以改为使用自联结,如下:
自联结通常作为外部语句,用来替代从相同表中检索数据的使用子查询语句。虽然最终结果是相同的,但很多DBMS处理联结比处理子查询要快得多。
②自然联结(natural join)
自然联结要求你只能选择那些唯一的列。一般通过对一个表使用通配符*,而对其他表的列使用明确的子集来完成。
事实上我们建立的内联结都是自然联结。
③外联结(outer join)
如果联结需要包含在相关表中没有关联行的行,我们用外联结。
如:要检索包括没有订单顾客在内的所有顾客,输入和输出如下:
如果此时用内联结,输入输出如下,可看到,内联结不会把没有订单的客户检索出来。
注意:在使用OUTER JOIN的语法时,必须使用RIGHT或LEFT关键字指定包括其所有行的表。(RIGHT指出的是OUTER JOIN右边的表,而LEFT指出的是OUTER JOIN左边的表。)上面的例子使用LEFTOUTER JOIN 从FROM子句左边的表中选择所有行。
如果使用RIGHT OUTER JOIN,结果如下:
3、使用带聚集函数的联结
需求:检索所有顾客及每个顾客所下的订单数
操作:输入输出如下,如果换成INNER JOIN,结果略有不同(结果的第2行没有)。
4、使用联结和联结条件
总结:
△ 一般用内联结,但使用外联结也有效
△ 使用联结时要提供联结条件
△ 在一个联结中可包含多个表,甚至可对每个联结采用不同联结类型。