JOIN怎么显示来自多个表的数据

71次阅读
没有评论

共计 2563 个字符,预计需要花费 7 分钟才能阅读完成。

这篇文章主要介绍“JOIN 怎么显示来自多个表的数据”,在日常操作中,相信很多人在 JOIN 怎么显示来自多个表的数据问题上存在疑惑,丸趣 TV 小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”JOIN 怎么显示来自多个表的数据”的疑惑有所帮助!接下来,请跟着丸趣 TV 小编一起来学习吧!

表关系简介

一、语法

SELECT 字段列表

 FROM TABLE1

[CROSS JOIN TABLE2] |

[NATURAL JOIN TABLE2] |

 [JOIN TABLE2 USING (字段名) ] |

 [JOIN TABLE2 ON (TABLE.COLUMN_NAME = TABLE2.COLUMN_NAME) ] |

[(LEFT | RIGHT | FULL OUT) JOIN TABLE2 ON (TABLE1.COLUMN_NAME = TABLE2.COLUMN_NAME) ];

二、自然连接

1、USING
如果不希望参照被连接表的所有同名列进行等值连接,自然连接将无法满足要求,可以在连接时使用 USING 子句来设置用于等值连接的列 (参照列) 名。
不允许在参照列上使用表名或者别名作为前缀

–99 语法

SELECT EMPNO, ENAME, SAL, EMP.DEPTNO, DNAME

 FROM EMP

 JOIN DEPT

 USING (DEPTNO);

 

 –92 语法

SELECT EMPNO, ENAME, SAL, EMP.DEPTNO, DNAME

 FROM EMP, DEPT

 WHERE EMP.DEPTNO = DEPT.DEPTNO;

2、ON
如果要参照非同名的列进行等值连接, 或想设置任意的连接条件, 可以使用 On 子句

SELECT EMPNO, ENAME, SAL, EMP.DEPTNO, DNAME

 FROM EMP

 JOIN DEPT

 ON (EMP.DEPTNO = DEPT.DEPTNO);

三、自连接

自己和自己做链接

–99 语法

SELECT WORKER.LAST_NAME EMP, MANAGER.LAST_NAME MGR

 FROM EMPLOYEES WORKER

 JOIN EMPLOYEES MANAGER

 ON (WORKER.MANAGER_ID = MANAGER.EMPLOYEE_ID);

 

–92 语法

SELECT WORKER.LAST_NAME EMP, MANAGER.LAST_NAME MGR

 FROM EMPLOYEES WORKER, EMPLOYEES MANAGER

 WHERE WORKER.MANAGER_ID = MANAGER.EMPLOYEE_ID;

四、非等值连接

–99 语法

SELECT E.LAST_NAME, E.SALARY, J.GRADE_LEVEL

 FROM EMPLOYEES E

 JOIN JOB_GRADES J

 ON E.SALARY BETWEEN J.LOWEST_SAL AND J.HIGHEST_SAL;

 

–92 语法

SELECT E.LAST_NAME, E.SALARY, J.GRADE_LEVEL

 FROM EMPLOYEES E, JOB_GRADES J

 WHERE E.SALARY BETWEEN J.LOWEST_SAL AND J.HIGHEST_SAL;

五、INNER|OUTER 连接

1、INNER 连接
两个表连接,只返回匹配的行,被称为内连接。

– 查询所有员工以及其部门名字

–99 语法

SELECT LAST_NAME, DEPARTMENT_NAME

 FROM EMPLOYEES E

 INNER JOIN DEPARTMENTS D

 ON E.DEPARTMENT_ID = D.DEPARTMENT_ID;

–92 语法

SELECT LAST_NAME, DEPARTMENT_NAME

 FROM EMPLOYEES E, DEPARTMENTS D

 WHERE E.DEPARTMENT_ID = D.DEPARTMENT_ID;

2、LEFT OUTER | RIGHT OUTER 连接
两个表在连接过程中除了返回满足连接条件的行以外还返回左(或右)表中不满足条件的行,这种连接称为左(或右)外连接。

– 哪些部门没有员工,看出部门名字

–99 语法

SELECT DEPARTMENT_NAME

 FROM EMPLOYEES E

 RIGHT JOIN DEPARTMENTS D

 ON E.DEPARTMENT_ID = D.DEPARTMENT_ID

 WHERE LAST_NAME IS NULL;

–92 语法

SELECT DEPARTMENT_NAME

 FROM EMPLOYEES E, DEPARTMENTS D

 WHERE E.DEPARTMENT_ID(+) = D.DEPARTMENT_ID

 AND LAST_NAME IS NULL;

3、FULL OUTER 连接
两个表在连接过程中除了返回满足连接条件的行以外还返回两个表中不满足条件的行,这种连接称为全外联接。

–99

SELECT E.LAST_NAME, D.DEPARTMENT_ID, D.DEPARTMENT_NAME

 FROM EMPLOYEES E

 FULL OUTER JOIN DEPARTMENTS D

 ON E.DEPARTMENT_ID = D.DEPARTMENT_ID;

–92

SELECT E.LAST_NAME, D.DEPARTMENT_ID, D.DEPARTMENT_NAME

 FROM EMPLOYEES E, DEPARTMENTS D

 ON E.DEPARTMENT_ID(+) = D.DEPARTMENT_ID(+);

六、笛卡尔积

笛卡尔集会在下面条件下产生:

1、连接条件被遗漏
2、连接条件不正确
3、所有表中的所有行互相连接

–99 语法

SELECT E.LAST_NAME, D.DEPARTMENT_ID, D.DEPARTMENT_NAME

 FROM EMPLOYEES E

 CROSS JOIN DEPARTMENTS D;

–92 语法

SELECT E.LAST_NAME, D.DEPARTMENT_ID, D.DEPARTMENT_NAME

 FROM EMPLOYEES E, DEPARTMENTS D;

到此,关于“JOIN 怎么显示来自多个表的数据”的学习就结束了,希望能够解决大家的疑惑。理论与实践的搭配能更好的帮助大家学习,快去试试吧!若想继续学习更多相关知识,请继续关注丸趣 TV 网站,丸趣 TV 小编会继续努力为大家带来更多实用的文章!

正文完
 
丸趣
版权声明:本站原创文章,由 丸趣 2023-07-15发表,共计2563字。
转载说明:除特殊说明外本站除技术相关以外文章皆由网络搜集发布,转载请注明出处。
评论(没有评论)