oracle中的函数

一、单行函数

     1.定义:作用于一行,返回值为一个

         注:以下所有的操作的表是Oracle数据库中自带的用户scott下的表

     2.字符函数

--小写变大写
select upper('yes') from dual;--YES
select lower('YES') from dual;--yes

      3.数值函数

select round(26.18,1) from dual;--四舍五入,后面的参数为保留几位小数,26.2
select trunc(26.18,1) from dual;--直接截取,不在看后面面的位数,26.1
select mod(10,3) from dual;--求余,1

      4.日期函数

         系统时间:sysdate

--查询emp表中所有员工入职距离现在几天
select sysdate-e.hiredate from emp e; 
--算出明天此刻
select sysdate+1 from dual;
--查询emp表中所有员工入职距离现在几个月
select months_between(sysdate,e.hiredate) from emp e;
--查询emp表中所有员工入职距离现在几个年
select months_between(sysdate,e.hiredate)/12 from emp e;

--查询emp表中所有员工入职距离现在几周
select round((sysdate-e.hiredate)/7) from emp e;
--转换函数 --日期转字符串 select to_char(sysdate,'fm yyyy-mm-dd hh24:mi:ss') from dual; --字符串传日期 select to_date('2020-4-3 14:9:37','fm yyyy-mm-dd hh24:mi:ss') from dual;

        5.通用函数 

--计算员工没年的工资:基础工资(sal)+ 奖金(comm),奖金中存在null值
--如果null值和任意数字做算数运算,结果都是null;
--nvl(e.comm,0)此函数表示e.comm不为空就用本身值,如果为空就用零
 select e.sal*12+nvl(e.comm,0) from emp e;

       6.条件表达式

--条件表达式
--给emp表中起一个中文名称
select e.ename,
       case e.ename
         when 'SMITH' then '老杜'
           when 'ALLEN' then '老李'
             when 'JONES' then '老张'
               else '无名'
                 end

from emp e;
--判断emp表中员工工资,如果>3000显示高收入,>3000 and <1500显示中等,其余低收入
 select e.sal,
       case 
         when e.sal>3000 then '高收入'
           when e.sal>1500 then '中等'
               else '低收入'
                 end

from emp e;
--oracle专用条件表达式
--Oracle中除了起别名用双引号,其他都用单引号
select e.ename,
       decode( e.ename,
          'SMITH' , '老杜',
            'ALLEN',  '老李',
              'JONES',  '老张',
                '无名') "中文名"
                 
from emp e;

二、多行函数[集合函数]

          定义:作用域多行,返回一个值。         

select count(1) from emp;  --查询总数量,count(1)和count(*)一样
select sum(sal) from emp; --工资总和
select max(sal) from emp;  --最大工资
select min(sal) from emp;   --最小工资
select avg(sal) from emp;   --工资平均

三、分组查询

--查询每个部门的平均工资
--分组查询中,出现在group by后面的原始列,才能出现在select后,其他的要加上聚合函数
select e.deptno,avg(e.sal)
from emp e
group by e.deptno;
--查询出平均工资高于2000部门信息
--所有条件不能使用别名
select e.deptno,avg(e.sal)
from emp e
group by e.deptno
having avg(e.sal)>2000;
--查询每个部门工资高于800的员工的平均工资
--where 是过滤分组之前的数据,having是过滤分组之后数据进行判断
select e.deptno,avg(e.sal)
from emp e
where e.sal>800
group by e.deptno;
--查询每个部门工资高于800的员工的平均工资,再查询出平均工资高于2000的部门
select e.deptno,avg(e.sal)
from emp e
where e.sal>800
group by e.deptno
having avg(e.sal)>2000;

四、连接

       1.等值连接           

select *
from emp e,dept d
where e.deptno=d.deptno;

        2.外连接     

--查询出所有部门,以及部门下的员工的信息【右外连接】
select *
from emp e right join dept d
on e.deptno=d.deptno;
--查询出所有员工的信息,以及员工所属的部门【左外连接】
select *
from emp e left join dept d
on e.deptno=d.deptno;
--oracle中的专业的外连接
select * 
from emp e,dept d
where e.deptno(+)=d.deptno;

        3.自连接

--查询员工姓名和员工领导姓名
select e1.ename,e2.ename
from emp e1,emp e2
where e1.mgr=e2.empno;
--查询员工姓名,员工部门名称,和员工领导姓名,员工领导部门名称
select e1.ename,d1.dname,d2.dname,e2.ename
from emp e1,emp e2,dept d1,dept d2
where e1.mgr=e2.empno and e1.deptno=d1.deptno and e2.deptno=d2.deptno;

五、子查询 

--子查询
--查询出工资和SCOTT一样的员工信息
select * from emp where sal in
(select sal from emp where ename='SCOTT');
--查询出工资和10号部门一样的员工信息
select * from emp where sal in(
select sal from emp where deptno=10);
--查询每个部门最低工资,和最低工资的员工姓名,和该员工所在部门名称
--先查询每个部门最低工资
select e.deptno,min(sal) msal
from emp e
group by e.deptno 


--最终结果
select t.deptno,t.msal,e.ename,d.dname
from (select e.deptno,min(sal) msal
from emp e
group by e.deptno) t,emp e,dept d
where t.deptno=e.deptno and t.msal=e.sal
and e.deptno=d.deptno;

六、分页查询

       1.oracle中的分页

          - - rownum行号:当我们做select操作时,没查询处一行记录就会在该行加上一个行号。

          - - 行号从1开始,依次递增,不能跳着走。

          - - 排序操作会影响rownum的顺序,如果要排序,还要使用rownum的话,我们可以使用嵌套查询。

--根据rownum排序
select rownum, t.* from(
select * from emp e order by e.sal desc
) t
--emp表工资倒叙排序后,每页五条记录,查询第二页
select * from 
(select rownum rn,t.* from(
select * from emp e order by e.sal desc
) t where rownum<11
) where rn>5 

 

上一篇:死锁模拟测试TM外键无索引情况


下一篇:01-SCOTT-SQL建表语句