--Upper  -------把字符转换成大写

      SELECT Upper ('abcde') FROM dual ;

--Lower   ----- 把字符转换成小写
      SELECT lower('ABCDE') FROM dual ; 
 
--Initcap  -----返回所有单词的首字母大写,其他字母小写
       Select initcap(ename) from emp; 
 
--Concat   -----字符串连接 ,相当于||
       Select concat('a','b')  from dual; 
        Select 'a' || 'b' from dual;

--Substr -------查找字符串
       Select substr('abcde',length('abcde')-2) from dual; 
       Select substr('abcde',-3,3) from dual;

substr(string,position,substring_length)

1、如果position=0,  则被当做1

2、如果position>1,    则从position位置开始找

3、如果position<1,    则从结尾开始找

4、如果第三个位置没有指定,则从指定位置到结尾

--Length ------字符串的长度
       Select length(dname) from dept;

--Replace -----字符串替换 
       Select replace(ename,'a','A') from emp;

--Instr -- -----字符串查找,返回索引值
       Select instr('Hello World','or') from dual; --8 indexof

--Lpad   ------左侧填充
       select lpad('Smith',10,'*') from dual--左侧填充  *****Smith

--Rpad   ------右侧填充
       select rpad('Smith',10,'*') from dual--右侧填充  Smith*****

--Trim   -------过滤首位空格 
       select trim('    Mr Smith          ') from dual --过滤首尾空格   Mr Smith

--数值函数

--Round   -----四舍五入,取精度
       select round(462,-2) from dual;      ------负数往小数点前数    ----500
       select round(412.313,2) from dual; -----正数往小数点后数     ----412.13

 --Trunc   -----不四舍五入,直接取最大值
       select trunc(462.13,-2) from dual;                                      ----400

--日期函数 
--Months_between()   -----两个时间之间隔了多少个月
       select months_between(sysdate,hiredate) from emp;

--Add_months()          ------在某个时间点上加一个月
        select add_months(sysdate,1) from dual;

--Next_day() 
        select next_day(sysdate,'星期一') from dual; ----返回下一个星期一的日期

--Last_day 
        select last_day(sysdate) from dual;             ----返回这个月的最后一天

--转换函数 

--To_char 
        select to_char(sysdate,'yyyy') from dual;            ---2011
         select to_char(sysdate,'yyyy-mm-dd') from dual; ----2011-07-16
         select to_char(sal,'L999,999,999') from emp;       ----
         select to_char(sysdate,'D') from dual; --返回星期  ----7

--To_number 
          select to_number('13')+to_number('14') from dual;    ------27

--To_date 
          Select to_date('2009-02-10','yyyy-MM-dd') from dual;  ----2009/2/10

select to_char('001') from dual;                                     ----001
         select to_number('003')from dual;                                -----3

--通用函数 
--NVL()函数    -----有值返回本身,无值返回0

        select nvl(comm,0) from emp;

--NULLIF()函数  ----如果表达式 exp1 与exp2 的值相等则返回 null,否则返回 exp1 的值

nullif(exp1,exp2)

--NVL2()函数    
      select empno, ename, sal, comm, nvl2(comm, sal+comm, sal) total from emp;   ----如果comm不为null,返回sal+comm,否则返回comm

--COALESCE()函数 --依次考察各参数表达式,遇到非null值即停止并返 回该值。

select empno, ename, sal, comm, coalesce(sal+comm, sal, 0)总收入  from emp;

--CASE表达式 
      select empno, ename, sal, 
           case deptno   
                when 10 then '财务部' 
                when 20 then '研发部' 
                when 30 then '销售部' 
                else '未知部门'       
          end 部门 
      from emp;

--DECODE()函数 --和 case表达式类似,decode()函数也用于实现多路分支结构 
 
       select empno, ename, sal, 
            decode(deptno, 10, '财务部', 
                                      20, '研发部', 
                                      30, '销售部', 
                                     '未知部门')       
                           部门 
       from emp;

 case在SQL中有两种写法,先建立一个表
         create table salgrade(grade int, sal int);

insert into salgrade values(1,1000);
         insert into salgrade values(2,2000);
         insert into salgrade values(3,3000);

第一种写法,简单写法:
         select grade,sal,
             case grade
                when 1 then 'low'
                when 2 then 'middle'
                else 'high'
            end
         from salgrade;

第二种写法,查找写法:
         SELECT grade,sal,
              case when sal <=1000 then 'low'
                  when sal <=2000 then 'middle'
                  else 'high'
             end
         FROM salgrade;

decode只能代替第一种写法:
          select grade,sal,decode(grade,1,'low',2,'middle','high') from salgrade;

--单行函数嵌套 
          select empno, lpad(initcap(trim(ename)),10,' ')    name, job, sal from emp;

Oracle单组函数的更多相关文章

  1. oracle常用函数总结(二)

    之前也有写过“oracle常用函数总结(一)”,为了尽量找全常见oracle函数,笔者特意查找了相关资料来作为参考,下边给大家罗列出来,部分和之前有重复的,希望能帮到大家! 列举了31个函数和1个分组 ...

  2. oracle add_months函数

    oracle add_months函数 add_months 函数主要是对日期函数进行操作,举例子进行说明 add_months 有两个参数,第一个参数是日期,第二个参数是对日期进行加减的数字(以月为 ...

  3. Oracle to_date()函数的用法

    Oracle to_date()函数的用法 to_date()是Oracle数据库函数的代表函数之一,下文对Oracle to_date()函数的几种用法作了详细的介绍说明,供您参考学习. 在Orac ...

  4. Oracle over函数

    Oracle over函数   SQL code: sql over的作用及用法RANK ( ) OVER ( [query_partition_clause] order_by_clause )DE ...

  5. Oracle常用函数

    前一段时间学习Oracle 时做的学习笔记,整理了一下,下面是分享的Oracle常用函数的部分笔记,以后还会分享其他部分的笔记,请大家批评指正. 1.Oracle 数据库中的to_date()函数的使 ...

  6. Oracle SQL函数

    Oracle将函数大致分为单行函数,聚合函数和分析函数. 单行函数分为字符函数,日期函数,转换函数,数字函数,通用函数,decode函数 一.字符函数 1)大小写控制函数 01.Lower() 全部小 ...

  7. Oracle trunc()函数的用法

    Oracle trunc()函数的用法 /**************日期********************/1.select trunc(sysdate) from dual --2013-0 ...

  8. oracle中函数和存储过程的区别和联系【转载竹沥半夏】

    oracle中函数和存储过程的区别和联系[转载竹沥半夏] 在oracle中,函数和存储过程是经常使用到的,他们的语法中有很多相似的地方,但也有自己的特点.刚学完函数和存储过程,下面来和大家分享一下自己 ...

  9. 转,Oracle中关于处理小数点位数的几个函数,取小数位数,Oracle查询函数

    关于处理小数点位数的几个oracle函数() 1. 取四舍五入的几位小数 select round(1.2345, 3) from dual; 结果:1.235 2. 保留两位小数,只舍 select ...

随机推荐

  1. 2014 Super Training #1 C Ice-sugar Gourd 模拟,扫描线

    原题 HDU 3363 http://acm.hdu.edu.cn/showproblem.php?pid=3363 给你一个串,串中有H跟T两种字符,然后切任意刀,使得能把H跟T各自分为原来的一半. ...

  2. 最长上升子序列(LIS)模板

    最长递增(上升)子序列问题:在一列数中寻找一些数,这些数满足:任意两个数a[i]和a[j],若i<j,必有a[i]<a[j],这样最长的子序列称为最长递增(上升)子序列. 考虑两个数a[x ...

  3. MySQL数据库学习笔记(二)----MySQL数据类型

    ​[声明] 欢迎转载,但请保留文章原始出处→_→ 生命壹号:http://www.cnblogs.com/smyhvae/ 文章来源:http://www.cnblogs.com/smyhvae/p/ ...

  4. Android 可拖拽的GridView效果实现, 长按可拖拽和item实时交换

    转帖请注明本文出自xiaanming的博客(http://blog.csdn.net/xiaanming/article/details/17718579),请尊重他人的辛勤劳动成果,谢谢! 在And ...

  5. smarty模板继承

  6. IDEA 滚动条跳动问题

    关掉有道词典的 “屏幕取词” 和 “划词翻译”

  7. Swift中的Masonry第三方库——SnapKit

        在OC开发时我常用一个名叫Masonry的第三方Autolayout库,在转Swift后发现虽然Swift可以混编OC,但总感觉有些麻烦,在Github上发现了这个叫做SnapKit的第三方库 ...

  8. usb驱动开发11之设备生命线

    暂时先告别媒人,我们去分析各自的生命旅程,最后还会回到usb_device_match函数. 首先当你将usb设备连接在hub的某个端口上,hub检测到有设备连接了进来,它会为设备分配一个struct ...

  9. 基于RESTful标准的Web Api

    微软的web api是在vs2012上的mvc4项目绑定发行的,它提出的web api是完全基于RESTful标准的,完全不同于之前的(同是SOAP协议的)wcf和webService,它是简单,代码 ...

  10. python 操作注册表

    import win32api import win32con keyname = r'Software\Microsoft\Internet Explorer\Main' page = 'www.l ...