oracle基本查询用法入门示例


当前第2页 返回上一页

分组函数作用于一组数据,并对一组数据返回一个值。
常用组函数

--AVG
--COUNT
--MAX
--MIN
--SUM
select sum(sal) as "total" from emp;
select max(sal) from emp;
select count(*) from emp where deptno=10;
select count(distinct deptno) from emp;

分组数据
通过GROUP BY可以将数据分成若干组

select deptno,avg(sal) from emp group by deptno;

(*注意:在select列表中所有未包含在组函数中的列都必须包含在group by中。)

--多列分组
select deptno,job,avg(sal) from emp group by deptno,job;

过滤分组
通过HAVING子句对分组进行过滤

select deptno,avg(sal) from emp group by deptno having deptno in(10,20);

(*注意:不能在where子句中使用组函数,having子句中可以。)
嵌套组函数

select max(avg(sal)) from emp group by deptno;

五、多表查询

oracle的连接  sql99的连接
等值连接        cross joins
不等值连接     natural joins
外连接           using clause
自连接           full or two sided outer joins

SELECT table1.column, table2.column
FROM table1,table2
WHERE table1.column1=table2.column2;
--等值连接
select d.dname,e.ename,e.sal from emp e, dept d where e.deptno=d.deptno;

--多连接条件和and操作符
select d.dname,e.ename,e.sal from emp e, dept d where e.deptno=d.deptno and e.deptno=10;

表的别名
1、使用表别名可简化查询
2、使用表名前缀可以提高执行效率
3、如果使用了表的别名,则不能再使用表的真名。

--不等值连接

--查询员工部门名称和工资等级
select d.dname, e.ename, e.sal, s.grade
from emp e, dept d, salgrade s
where e.deptno = d.deptno
and e.sal >= s.losal
and e.sal <= s.hisal;

外连接语法
外连接查询可以查询不满足连接条件的数据。
外连接的符号是(+)

SELECT table1.column, table2.column
FROM table1, table2
WHERE table1.column(+) = table2.column;

SELECT table1.column, table2.column
FROM table1, table2
WHERE table1.column= table2.column(+) ;
--查询部门人数
select d.dname, d.deptno, count(e.empno)
 from emp e, dept d
 where e.deptno(+) = d.deptno
 group by d.deptno,d.dname;

自连接

--查询员工的上级
select e.ename as "员工", e2.ename as "上级"
 from emp e, emp e2
 where e.empno = e2.mgr;

使用sql:1999语法连接

SELECT table1.column, table2.column
FROM table1
[CROSS JOIN table2] |
[NATURAL JOIN table2] |
[JOIN table2 USING (column_name)] |
[JOIN table2 ON(table1.column_name=table2.column_name)] |
[LEFT|RIGHT|FULL OUTER JOIN table2 ON(table1.column_name=table2.column_name)];

使用cross join连接的表产生叉集,叉集和笛卡尔集是相同的。

select e.ename,d.dname from emp e cross join dept d;

使作natural join自然连接,会以两个表中具有相同名字的列为条件创建等值连接。

select e.ename,d.dname from emp e natural join dept d;

使用using创建连接,用natural join创建等值连接时,可以使用using指定等值连接中需要用到的列。

select e.ename,d.dname from emp e join dept d USING (deptno);

使用on创建连接,可以指定额外的连接条件。

select e.ename,d.dname from emp e join dept d on e.deptno=d.deptno;

使用on创建多表连接

select e.ename, d.dname, e2.ename
from emp e
join dept d
on e.deptno = d.deptno
join emp e2
on e.empno = e2.mgr;

内连接和外连接
在sql:1999中,内连接只返回满足连接条件的数据。
两个表在连接过程中除了返回满足连接条件的行以外,还返回左(右)表中不满足条件的行,这种称为左(右)外连接。
两个表在连接过程中除了返加满足连接条件的行以外,还返回两个表中不满足条件的行,这种连接称为满外连接。

--左外连接
select e.ename, d.dname
from emp e
left outer join dept d
on e.deptno = d.deptno;
--右外连接,返回右表中不满足条件的行
select e.ename, d.dname
from emp e
right outer join dept d
on e.deptno = d.deptno;
--满外连接
select e.ename, d.dname
from emp e
full outer join dept d
on e.deptno = d.deptno;

更多关于Oracle相关内容感兴趣的读者可查看本站专题:《Oracle常用函数汇总》、《Oracle日期与时间操作技巧总结》及《php+Oracle数据库程序设计技巧总结》

希望本文所述对大家Oracle数据库程序设计有所帮助。


标签:Oracle

返回前面的内容

相关阅读 >>

windowsserver2016安装oracle11g的图文教程

postgresql的now()与oracle的sysdate区别说明

oracle表分区详解

oracle 11g release (11.1) 索引底层的数据结构

linux 自动备份oracle数据库详解

oracle 报警日志如何查看?

oracle存储过程是什么?

详解oracle中存储函数与存储过程

navicat怎么连oracle

实例优化oracle数据库性能

更多相关阅读请进入《oracle》频道 >>


数据库系统概念 第6版
书籍

数据库系统概念 第6版

机械工业出版社

本书主要讲述了数据模型、基于对象的数据库和XML、数据存储和查询、事务管理、体系结构等方面的内容。



打赏

取消

感谢您的支持,我会继续努力的!

扫码支持
扫码打赏,您说多少就多少

打开支付宝扫一扫,即可进行扫码打赏哦

分享从这里开始,精彩与您同在

评论

管理员已关闭评论功能...