Oracle外连接和内连接
来源:互联网 发布:网络直播的研究意义 编辑:程序博客网 时间:2024/05/23 22:37
1. 内连接很简单
select A.*, B.* from A,B where A.id = B.id
select A.*, B.* from A inner join B on A.id = B.id
以上两句是完全等价的
2. 左外连接
select * from emp a left join dept d on a.deptno=d.deptno
select * from emp a,dept d where a.deptno=d.deptno(+)
以上两句是完全等价的
3. 右外连接
select * from emp a right join dept d on a.deptno=d.deptno
select * from emp a,dept d where a.deptno(+)=d.deptno
以上两句是完全等价的
也就是说只要把语句中的表换个位置,右外和左外就可以起到同样的功能
Oracle中可以使用“(+) ”来表示,9i可以使用LEFT/RIGHT/FULL OUTER JOIN
LEFT OUTER JOIN:左外关联
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);
等价于
SELECT e.last_name, e.department_id, d.department_name
FROM employees e, departments d
WHERE e.department_id=d.department_id(+)
结果为:所有员工及对应部门的记录,包括没有对应部门编号department_id的员工记录。
RIGHT OUTER JOIN:右外关联
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);
等价于
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:全外关联
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);
结果为:所有员工及对应部门的记录,包括没有对应部门编号department_id的员工记录和没有任何员工的部门记录。
SQL--JOIN之完全用法
外联接。外联接可以是左向外联接、右向外联接或完整外部联接。
在 FROM 子句中指定外联接时,可以由下列几组关键字中的一组指定:
LEFT JOIN 或 LEFT OUTER JOIN。
左向外联接的结果集包括 LEFT OUTER 子句中指定的左表的所有行,而不仅仅是联接列所匹配的行。如果左表的某行在右表中没有匹配行,则在相关联的结果集行中右表的所有选择列表列均为空值。
- Oracle外连接和内连接
- Oracle 内连接和外连接
- oracle中的内连接和外连接
- oracle 内连接和外连接
- oracle表内连接和外连接
- oracle表内连接和外连接
- Oracle的外连接内连接和自连接
- Oracle内连接、外连接
- oracle内连接 外连接
- oracle 连接内连接,外连接
- 内连接和外连接
- 内连接和外连接
- 内连接和外连接
- 内连接和外连接
- 内连接和外连接
- 内连接和外连接
- 内连接和外连接
- 内连接和外连接
- Java软件低级错误(二十 ):正确理解String/StringBuffer/StringBuilder的性能区别
- c-free 5.0使用遇到问题
- 事务对于自定义异常的处理
- utf8乱码解决方案[适合tomcat部署的jsp应用]
- Android手机开发:Menu功能
- Oracle外连接和内连接
- Jquery键盘事件处理插件及DEMO
- java中实践格式化
- C和C++混合编程(__cplusplus 与 external "c" 的使用)
- head first 装饰者模式 -- 借助继承
- 使用 ipmitool 实现 Linux 系统下对服务器的 ipmi 管理
- 诺基亚技术支持提供的 qml json 交互
- Java软件低级错误(十 五):大小写转换的正确处理
- web.xml 中的listener、 filter、servlet 加载顺序及其详解