Oracle DBA 面试及答案-经典
### Oracle DBA 面试及答案 - 经典知识点详解 #### 一、表连接方式 表连接是数据库操作中最常见的技术之一,用于合并来自两个或更多表的数据。Oracle 提供了多种连接方式,每种都有其特定的应用场景。 ##### 1. 等连接(内连接) 等连接是最基本的连接类型,它返回两个表中基于连接列相等的行。例如: ```sql SELECT * FROM a, b WHERE a.id = b.id; ``` 这条语句会返回表`a`和表`b`中`id`相同的行。 ##### 2. 非等连接 非等连接是指通过除等号(`=`)之外的条件进行连接,如小于、大于等比较运算符。例如: ```sql SELECT A.c1, B.c2 FROM A JOIN B ON A.c3 != B.c3; ``` 这条语句将返回表`A`和表`B`中`c3`不相等的所有组合。 ##### 3. 自连接 自连接是指同一个表中的不同行之间的连接。例如: ```sql SELECT e1.last_name, e2.last_name FROM employees e1, employees e2 WHERE e1.manager_id = e2.employee_id; ``` 这条语句将返回每个员工及其直接下属的名字。 ##### 4. 外连接 外连接可以分为左外连接、右外连接和全外连接。 - **左外连接(LEFT OUTER JOIN)** 左外连接返回左表的所有行,并且返回右表中符合条件的行;如果右表中没有符合条件的行,则返回NULL值。例如: ```sql SELECT e.last_name, e.department_id, d.department_name FROM employees e LEFT OUTER JOIN departments d ON (e.department_id = d.department_id); ``` 或者等价地: ```sql SELECT e.last_name, e.department_id, d.department_name FROM employees e, departments d WHERE e.department_id = d.department_id(+); ``` - **右外连接(RIGHT OUTER JOIN)** 右外连接返回右表的所有行,并且返回左表中符合条件的行;如果左表中没有符合条件的行,则返回NULL值。例如: ```sql SELECT e.last_name, e.department_id, d.department_name FROM employees e RIGHT OUTER JOIN departments d ON (e.department_id = d.department_id); ``` 或者等价地: ```sql SELECT e.last_name, e.department_id, d.department_name FROM employees e, departments d WHERE e.department_id(+) = d.department_id; ``` - **全外连接(FULL OUTER JOIN)** 全外连接返回左表和右表中的所有行,并且返回左表和右表中都有的行;如果任一边没有符合条件的行,则返回NULL值。例如: ```sql SELECT e.last_name, e.department_id, d.department_name FROM employees e FULL OUTER JOIN departments d ON (e.department_id = d.department_id); ``` 在Oracle 8i中,可以使用以下语法实现全外连接: ```sql SELECT t1.id, t2.id FROM table1 t1, table2 t2 WHERE t1.id = t2.id(+) UNION SELECT t1.id, t2.id FROM table1 t1, table2 t2 WHERE t1.id(+) = t2.id; ``` ##### 5. (Theta)连接 (Theta)连接是一种特殊的连接方式,它使用除等号以外的其他逻辑运算符来匹配表中的行。例如: ```sql SELECT A.c1, B.c2 FROM A JOIN B ON A.c3 < B.c3; ``` 这条语句将返回表`A`和表`B`中满足`c3`列小于关系的所有组合。 ##### 6. 交叉连接 交叉连接返回所有可能的组合,即第一个表的每一行与第二个表的所有行组合。例如: ```sql SELECT A.c1, B.c2 FROM A, B; ``` 这条语句将返回表`A`与表`B`的所有可能的组合。 #### 二、查看SQL执行计划 在Oracle中,查看SQL语句的执行计划是非常重要的,这有助于优化查询性能。有几种不同的方法可以查看SQL执行计划: 1. **使用EXPLAIN PLAN** 使用EXPLAIN PLAN可以将SQL语句的执行计划存储到一个名为PLAN_TABLE的表中,然后可以通过查询该表来查看具体的执行计划。 示例代码如下: ```sql -- 设置执行计划 EXPLAIN PLAN SET STATEMENT_ID = 'QUERY1' FOR SELECT * FROM a WHERE aa = 1; -- 查询执行计划 SELECT operation, options FROM PLAN_TABLE; ``` 这里使用`EXPLAIN PLAN`设置执行计划,并使用`STATEMENT_ID`参数标识执行计划,然后通过查询`PLAN_TABLE`来查看具体的执行步骤。 以上就是关于Oracle DBA面试中关于表连接方式及如何查看SQL执行计划的经典知识点详解。这些知识点不仅适用于面试准备,也是日常工作中非常实用的技术点。掌握这些内容可以帮助你在数据库管理和优化方面更加得心应手。
剩余25页未读,继续阅读
- 粉丝: 507
- 资源: 1979
- 我的内容管理 展开
- 我的资源 快来上传第一个资源
- 我的收益 登录查看自己的收益
- 我的积分 登录查看自己的积分
- 我的C币 登录后查看C币余额
- 我的收藏
- 我的下载
- 下载帮助