例如: 2, SELECT A.NO,B.NAME FROM A,B WHERE A.NO(+)=10 AND A.NO(+)=B.NO 中: A.No(+)=10 是什么意思啊?? 后面的A.NO(+)=B.NO我知道,是A为附表主要是前面的是什么意思搞不明白 谢谢关注
(1) SELECT A.NO,B.NAME FROM A,B WHERE A.NO(+)=10 AND A.NO(+)=B.NO (2) SELECT A.NO,B.NAME FROM A,B WHERE A.NO=10 AND A.NO(+)=B.NO(1)和(2)的结果可能不同,(2)句相当于这句 SELECT A.NO,B.NAME FROM A,B WHERE A.NO=10 AND A.NO=B.NO 所以为了实现外连接,A.NO后面一定也要有(+),到了9i最好用outer joinSELECT A.NO,B.NAME FROM A RIGHT OUTER JOIN B ON(A.NO=B.NO) WHERE A.NO=10;
B.No(+)=10 没什么用的。和B.No=10 没什么区别
只是SQL优化的时候,工具自己加上去的
Oracle的左连接和右连接 作者:unknown 更新时间:2005-03-19 在Oracle PL-SQL中,左连接和右连接以如下方式来实现 查看如下语句: SELECT emp_name, dept_name FORM Employee, Department WHERE Employee.emp_deptid(+) = Department.deptid此SQL文使用了右连接,即“(+)”所在位置的另一侧为连接的方向,右连接说明等号右侧的所有记录均会被显示,无论其在左侧是否得到匹配,也就是说上例中无论会不会出现某个部门没有一个员工的情况,这个部门的名字都会在查询结果中出现。反之: SELECT emp_name, dept_name FORM Employee, Department WHERE Employee.emp_deptid = Department.deptid(+)则是左连接,无论这个员工有没有一个能在Department表中得到匹配的部门号,这个员工的记录都会被显示============================================================================ 表的左右连接 比如表A id name 1 A1 2 A2 3 A3 5 A5 表B id name 1 B1 3 B3 4 B4 6 B6 1.select a.id,a.name,b.id,b.name from A a,B b where a.id=b.id; 交集 id name id name 1 A1 1 B1 3 A3 3 B3 2.select a.id,a.name,b.id,b.name from A a,B b where a.id(+)=b.id; id name id name 1 A1 1 B1 3 A3 3 B3 4 B4 6 B6 3.select a.id,a.name,b.id,b.name from A a,B b where a.id=b.id(+); id name id name 1 A1 1 B1 2 A2 3 A3 3 B3 5 A5 ============================================================================ select * from a, b where a.id = b.id; 对于外连接,Oracle中可以使用“(+)”来表示,9i可以使用LEFT/RIGHT/FULL OUTER JOIN,下面将配合实例一一介绍。 1. 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的员工记录。 2. 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; 结果为:所有员工及对应部门的记录,包括没有任何员工的部门记录。 3. 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的员工记录和没有任何员工的部门记录。
对左右连接不清楚地看楼上的对b.no(+)=1 不清楚,看我下面的解说 主要是这两种得比较,其他大同小异 1, SELECT A.NO,B.NAME FROM A,B WHERE A.NO=10 AND A.NO(+)=B.NO ㊤説明:等同于 a.no=b.no 2, SELECT A.NO,B.NAME FROM A,B WHERE A.NO(+)=10 AND A.NO(+)=B.NO ㊤说明:取出两个表中,只等于10对应的纪录 + 主表中非10的数据记录 a.no b.no 10 10 10 10 2 3 4 5如果还没看明白就给我发消息哈 谢谢大家的关注
2, SELECT A.NO,B.NAME
FROM A,B
WHERE A.NO(+)=10 AND A.NO(+)=B.NO
中: A.No(+)=10 是什么意思啊?? 后面的A.NO(+)=B.NO我知道,是A为附表主要是前面的是什么意思搞不明白
谢谢关注
FROM A,B
WHERE A.NO(+)=10 AND A.NO(+)=B.NO
(2) SELECT A.NO,B.NAME
FROM A,B
WHERE A.NO=10 AND A.NO(+)=B.NO(1)和(2)的结果可能不同,(2)句相当于这句
SELECT A.NO,B.NAME
FROM A,B
WHERE A.NO=10 AND A.NO=B.NO
所以为了实现外连接,A.NO后面一定也要有(+),到了9i最好用outer joinSELECT A.NO,B.NAME
FROM A
RIGHT OUTER JOIN B
ON(A.NO=B.NO)
WHERE A.NO=10;
没什么用的。和B.No=10 没什么区别
作者:unknown 更新时间:2005-03-19
在Oracle PL-SQL中,左连接和右连接以如下方式来实现 查看如下语句:
SELECT emp_name, dept_name
FORM Employee, Department
WHERE Employee.emp_deptid(+) = Department.deptid此SQL文使用了右连接,即“(+)”所在位置的另一侧为连接的方向,右连接说明等号右侧的所有记录均会被显示,无论其在左侧是否得到匹配,也就是说上例中无论会不会出现某个部门没有一个员工的情况,这个部门的名字都会在查询结果中出现。反之:
SELECT emp_name, dept_name
FORM Employee, Department
WHERE Employee.emp_deptid = Department.deptid(+)则是左连接,无论这个员工有没有一个能在Department表中得到匹配的部门号,这个员工的记录都会被显示============================================================================
表的左右连接
比如表A
id name
1 A1
2 A2
3 A3
5 A5
表B
id name
1 B1
3 B3
4 B4
6 B6
1.select a.id,a.name,b.id,b.name from A a,B b where a.id=b.id;
交集
id name id name
1 A1 1 B1
3 A3 3 B3
2.select a.id,a.name,b.id,b.name from A a,B b where a.id(+)=b.id;
id name id name
1 A1 1 B1
3 A3 3 B3
4 B4
6 B6
3.select a.id,a.name,b.id,b.name from A a,B b where a.id=b.id(+);
id name id name
1 A1 1 B1
2 A2
3 A3 3 B3
5 A5
============================================================================
select * from a, b where a.id = b.id; 对于外连接,Oracle中可以使用“(+)”来表示,9i可以使用LEFT/RIGHT/FULL OUTER JOIN,下面将配合实例一一介绍。 1. 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的员工记录。 2. 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; 结果为:所有员工及对应部门的记录,包括没有任何员工的部门记录。 3. 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的员工记录和没有任何员工的部门记录。
主要是这两种得比较,其他大同小异
1, SELECT A.NO,B.NAME
FROM A,B
WHERE A.NO=10 AND A.NO(+)=B.NO
㊤説明:等同于 a.no=b.no
2, SELECT A.NO,B.NAME
FROM A,B
WHERE A.NO(+)=10 AND A.NO(+)=B.NO
㊤说明:取出两个表中,只等于10对应的纪录 + 主表中非10的数据记录 a.no b.no
10 10
10 10
2
3
4
5如果还没看明白就给我发消息哈
谢谢大家的关注