WEB开发网      婵犻潧鍊婚弲顐︽偟椤栨稓闄勯柦妯侯槸閻庤霉濠婂骸浜剧紒杈ㄥ笚閹峰懘鎮╅崹顐ゆ殸婵炴垶鎸撮崑鎾趁归悩鐑橆棄闁搞劌瀛╃粋宥夘敃閿濆柊锕傛煙鐎涙ê鐏f繝濠冨灴閹啴宕熼鍡╀紘婵炲濮惧Λ鍕叏閳哄懎绀夋繛鎴濈-楠炪垽鎮归崶褍妲婚柛銊ュ缁傚秹鏁撻敓锟� ---闂佹寧娲╅幏锟�
开发学院数据库Oracle ORACLE的外连接 阅读

ORACLE的外连接

 2009-01-24 04:57:50 来源:WEB开发网 闂侀潧妫撮幏锟�闂佸憡鍨电换鎰版儍椤掑倵鍋撳☉娆嶄沪缂傚稄鎷�婵犫拃鍛粶闁靛洤娲ㄩ埀顒佺⊕閵囩偟绱為敓锟�闂侀潧妫撮幏锟�  闂佺ǹ绻楀▍鏇㈠极閻愬灚瀚梺鍨儏閳ь剙绉归弻銊р偓闈涙啞閻h京鈧敻鍋婇崰鏍х暦閿燂拷
核心提示:问:ORACLE 中 外连接 是什么意思?刚看了个教程还是不太明白 SELECT e.last_name, e.department_id, d.department_name FROM employees e, departments d WHERE e.department_id=d.department_id(+

问:

ORACLE 中 外连接 是什么意思?

刚看了个教程还是不太明白
SELECT e.last_name, e.department_id, d.department_name
FROM employees e, departments d
WHERE e.department_id=d.department_id(+);

结果为:所有员工及对应部门的记录,包括没有对应部门编号department_id的员工记录。

疑问:从数据库中取出的是怎么样的?
是不是
employees 表中所有员工都取出,如:e.last_name, e.department_id全部都取出

department表中只取employees中员工对应的d.department_name

??

请大虾们求教!

答:

这是外连接的一种,基本的执行流程就像你所说的。

以employees表为主来做连接,循环扫描employees表中所有员工,对于每一个员工如果在department中如果,有何他的部门号相同的部门,则进行连接生成一个新纪录e.last_name, e.department_id,d.department_name。

如果没有和部门号相同的部门,同样生成一个新纪录e.last_name, e.department_id,NULL。

注意这只是一个特例,因为是通过外键来做连接的,所以匹配的纪录也只有一条。有的时候,匹配的记录可能有多条。但是如果不匹配的话,则只有一条记录进入结果。

Tags:ORACLE 连接

编辑录入:爽爽 [复制链接] [打 印]
赞助商链接