扫二维码与项目经理沟通
我们在微信上24小时期待你的声音
解答本文疑问/技术咨询/运营咨询/技术建议/互联网交流
创建表:
创新互联建站致力于网站设计制作、成都做网站,成都网站设计,集团网站建设等服务标准化,推过标准化降低中小企业的建站的成本,并持续提升建站的定制化服务水平进行质量交付,让企业网站从市场竞争中脱颖而出。 选择创新互联建站,就选择了安全、稳定、美观的网站建设服务!
create table a
(id int,
value varchar2(1));
create table b
(id int,
value varchar2(1));
insert into a values (1,'A');
insert into a values (1,'B');
insert into a values (2,'A');
insert into a values (2,'B');
insert into a values (2,'C');
insert into b values (1,'A');
insert into b values (1,'B');
insert into b values (1,'C');
insert into b values (2,'A');
insert into b values (2,'B');
commit;
执行:
select nvl(a.id,b.id) id,a.value,b.value from a full join b on a.id=b.id and a.value=b.value order by id,a.value
结果:
select e.empno, e.ename, d.deptno, d.dname
from emp e, dept d
where e.deptno = d.deptno;
在之前所使用的查询操作之中,都是从一张表之中查询出所需要的内容,那么如果现在一个查询语句需要显示多张表的数据,则就必须应用到多表查询的操作,而多表查询的语法如下:
SELECT [DISTINCT] * | 字段 [别名] [,字段 [别名] ,…] FROM 表名称 [别名], [表名称 [别名] ,…] [WHERE 条件(S)] [ORDER BY 排序字段 [ASC|DESC] [,排序字段 [ASC|DESC] ,…]]。
扩展资料:
Oracle 常用的关联查询:
Oracle外连接:
(1)左外连接 (左边的表不加限制)。
(2)右外连接(右边的表不加限制)。
(3)全外连接(左右两表都不加限制)。
outer join则会返回每个满足第一个(顶端)输入与第二个(底端)输入的联接的行。它还返回任何在第二个输入中没有匹配行的第一个输入中的行。
外连接分为三种: 左外连接,右外连接,全外连接。 对应SQL:LEFT/RIGHT/FULL OUTER JOIN。 通常我们省略outer 这个关键字。 写成:LEFT/RIGHT/FULL JOIN。
在左外连接和右外连接时都会以一张表为基表,该表的内容会全部显示,然后加上两张表匹配的内容。 如果基表的数据在另一张表没有记录。 那么在相关联的结果集行中列显示为空值(NULL)。
--实验用表:
CREATE TABLE A(NAME VARCHAR2(10), DEPTID VARCHAR2(2));
CREATE TABLE B(ID VARCHAR2(10), DEPTID VARCHAR2(2), NUM VARCHAR2(2), CREATE_TIME DATE);
--查询某一时间段内;全部部门及其业务量
SELECT A.NAME, COUNT(B.ID), SUM(B.NUM) AS 部门业务量
FROM A A, B B
WHERE A.DEPTID = B.DEPTID(+)
AND B.CREATE_TIME TO_DATE('20141001', 'yyyyMMdd')
AND B.CREATE_TIME TO_DATE('20141022', 'yyyyMMdd')
GROUP BY A.NAME;
我们在微信上24小时期待你的声音
解答本文疑问/技术咨询/运营咨询/技术建议/互联网交流