单行函数
============================================================
特点:
每行返回一个结果,输入输出存在一一对应的关系
能嵌套使用 ,一个函数的输出能做另外一个函数的输入 如:select lowner(upper(‘aa‘)) from dual;
传入的变量可以是列的值,也可以是表达式。 如 select lower(ename) from emp;
============================================================
转换函数:
to_number: 将字符类型的数据转换为数字类型
to_date:将字符类型的数据转换为日期类型d
to_char:将number或者是date类型的数据转换为字符类型
============================================================
1.1、to_char:将时间类型的数据转换为字符类型
语法:to_char(date,‘format_model‘)
format_model:日期格式类型
yyyy 数字年份形式 四位数
year 年份的拼写形式
mm 数字日期形式
month 月份的全拼格式
mon 月份的简写 三位数
dy 星期的简写 三位数
day 星期的全写
dd 数字形式日期 两位数
例如:
①查询当前时间,时间格式显示为2011-01-02 12:10:13
SQL>select sysdate from dual; ----显示默认的时间格式
SQL>select to_char(sysdate,‘yyyy-mm-dd hh24:mi:ss‘) from dual;
②查询当前时间,时间格式显示为 “星期全写 四位年 月份全写"
SQL>select to_char(sysdate,‘day yyyy month‘) from dual;
③fm的使用 去掉前导0
SQL> select to_char(sysdate-13,‘dd‘) from dual;
TO
--
07
SQL> select to_char(sysdate-13,‘fmdd‘) from dual;
TO
--
7
④日期格式里面插入字符,需要用双引号把字符引起来,如” 星期全写 victor 四位年 月份全写"
SQL>select to_char(sysdate,‘day "victor" yyyy month‘) from dual;
============================================================
1.2、to_char:将数字类型的数据转换为字符类型
语法:to_char(number,‘format_model‘)
format_model:格式类型
9 ----有多少个number(就是多少位) 都真实的显示出来,如果前面是0的,后面是number的,前面的0不显示
0 ----有多少位就显示多少位,不足的用0填充
$ ----用美元显示
L ----使用本地货币符号
.
,
①测试9和0的区别:想要把工资显示为x,xxx.xx这种格式
SQL>select ename,to_char(sal,‘9,999.99‘) from emp;
改成
SQL>select ename,to_char(sal,‘9,009.09‘) from emp;
发现没有区别,因为9和0都是表示一位数字
---------------------------------------------------------------------------------------
改成
SQL>select ename,to_char(sal,‘0,999.99‘) from emp;
现在需要显示4位数,800要显示为0800,由于前面是0,那就是说不够的用0填充
---------------------------------------------------------------------------------------
改成
SQL>select ename,to_char(sal,‘09909090,999.99‘) from emp;
总结:9和0都是表示一个数字,0表示不足位的时候用0去填充,一般只用在前导位。
============================================================
2、to_number:用于将字符类型转换为数字类型
SQL>select to_number(‘234234.4350‘,‘999999.0000‘) from dual;
TO_NUMBER(‘RMB234234.4350‘,‘L999999.0000‘)
——————————————
234234.435
①用于将16进制转化为10进制
SQL>select to_number(‘fa‘,‘xxxxx‘) from dual;
============================================================
3、to_date:用于将数据转换为日期类型
语法:to_date(‘char‘,‘format_model‘)
format_model:格式类型
yyyy 数字年份形式 四位数
year 年份的拼写形式
mm 数字日期形式
month 月份的全拼格式
mon 月份的简写 三位数
dy 星期的简写 三位数
day 星期的全写
dd 数字形式日期 两位数
①select * from emp where hiredate < to_date(‘1986-07-25‘,‘yyyy-mm-dd‘);
============================================================
4、空值函数
①NVL(expr1,expr2):对expr1进行判断,如果expr1为空,则返回expr2,如果expr1不为空,则返回expr1本身
SQL>select ename,comm,nvl(comm,0) from emp;
注意:数据类型需要匹配,如expr1为number,那么expr2也要为number,否则会报错
②NVL2(exp1,expr2,expr3):对expr1进行判断,如果expr1为空,则返回expr3,如果expr1不为空,则返回expr2;
SQL>select ename,comm,nvl2(comm,1,0) from emp;
③NULLIF(expr1,expr2):如果expr1和expr2相等,则返回null,否则返回expr1
SQL> select sal,nullif(sal,3000) from emp;
============================================================
5、条件表达式
①case的语法:
case expr when expr1 when return_expr1
when expr2 when return_expr2
when expr3 when return_expr3
else else_expr
end;
eg:对deptno进行判断,如果10号部门,返回一倍工资(1*sal),如果是20号部门,返回两倍工资(2*sal),如果是30,返回3倍工资,如果都不是,则返回一半工资
select ename,deptno,sal,
case deptno
when 10 then 1*sal
when 20 then 2*sal
when 30 then 3*sal
else sal/2
end
from emp;
②decode:decode(expr1,expr2,expr3,.........)
eg:对deptno进行判断,如果是10号部门,返回一倍工资(1*sal),如果不是,则返回0。
SQL>select ename,deptno,sal,decode(deptno,10,sal,0) from emp;
eg:对deptno进行判断,如果是10号部门,返回一倍工资(1*sal);如果是30号部门,返回30倍工资(30*sal);如果是41号部门,返回50。
SQL>select ename,deptno,sal,decode(deptno,10,sal,30,30*sal,41,50) from emp;
使用decode 改写case中的列子
SQL>select ename,deptno,sal,decode(deptno,10,sal,20,2*sal,30,3*sal,sal/2) from emp;