SQL高级查询技巧(两次JOIN同一个表,自包含JOIN,不等JOIN)

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了SQL高级查询技巧(两次JOIN同一个表,自包含JOIN,不等JOIN)相关的知识,希望对你有一定的参考价值。

掌握了这些,就比较高级啦

Using the Same Table Twice

如下面查询中的branch字段

SELECT a.account_id, e.emp_id, b_a.name open_branch, b_e.name emp_branch FROM account AS a INNER JOIN branch AS b_a ON a.open_branch_id = b_a.branch_id INNER JOIN employee AS e ON a.open_emp_id = e.emp_id INNER JOIN branch b_e ON e.assigned_branch_id = b_e.branch_id WHERE a.product_cd = CHK;

 

Self-Joins

因为employee中自引用了自己的上级,所以存在这个可能性,django example里也有这样的CASE

SELECT e.fname, e.lname, e_mgr.fname mgr_fname, e_mgr.lname mgr_lname FROM employee AS e INNER JOIN employee AS e_mgr ON e.superior_emp_id = e_mgr.emp_id;

 

Non-Equi-Joins

在JOIN语句的ON条件中,不一定非要用等号,也可以不等号

 SELECT e1.fname, e1.lname, VS vs, e2.fname, e2.lname FROM employee AS e1 INNER JOIN employee AS e2 ON e1.emp_id < e2.emp_id WHERE e1.title = Teller AND e2.title = Teller;

技术分享

以上是关于SQL高级查询技巧(两次JOIN同一个表,自包含JOIN,不等JOIN)的主要内容,如果未能解决你的问题,请参考以下文章

SQL高级查询技巧

何时在包含 JOIN 和聚合的 SQL 查询中使用 *?

至少一个表包含所需值时的 SQL JOIN:这可以在单个查询中实现吗?

sql中join on两个条件怎么写

高级T-SQL进阶系列 :使用 CROSS JOIN 介绍高级T-SQL

通过 LEFT JOIN 优化 SQL 子查询