四、转换函数与条件表达式
转换函数:conversion functions
数据类型转换:data type conversion
隐式数据类型转换:implict data type conversion
显示数据类型转换:explicit data type conversion
隐式转换:
1、在表达式中Oracle服务器能自动转换的
varchar2 or char >> number
varchar2 or char >> date
number >> varchar2 or char
date >> varchar2 or char
显示转换
number >to_char> character
character >to_number> number
date >to_date> character
character >to_date> date
to_char 处理日期
to_char(date,'format_model')
必须用引号引起来
区分大小写
可用有效日期格式元素
逗号与日期隔开
日期元素:
YYYY,YEAR
MM,MONTH,MON
DY,DAY,DD
to_char 函数处理数字
to_char(number,'format_model')
9 返回一个数字
0 强制返回0
$ 放置浮动美元符号
L 使用本地货币浮动符号
. 打印小数点
, 打印逗号作为千位指示器
数字到字符
to_char(sal,'$99,999.00')
转字符为数字用to_number
转字符为日期用to_date
嵌套函数:nesting functions
1、单行函数可以嵌套多层
2、嵌套函数的计算过程是从最内层到最外层
F3(F2(F1(co1,arg1),arg2),arg3)
第三步 第二步 第一步
从里向外
例
select ename,upper(concat(substr(ename,1,8),'_us')) from emp
where deptno=10;
部门10中,名字截取前八个字符,再拼接上'_us'最后变成大写
select to_char(round((sal/7),2),'99g999d99') from emp;
空值函数:general functions
1、NVL(exper1,exper2) 1为空就返回2
2、NVL2(exper1,exper2,exper3) 1不为空返回2,为空返回3
3、NULLIF(exper1,exper2) 相同返回空,不同返回1
4、COALESCE(exper1,exper2,....,expern) 返回第一个不为空的值
NVL函数适用于数字,字符,日期,并且前后数据类型要匹配
条件表达式:conditional expressions
提供if-then-else 逻辑判断
case和decode函数
SQL> SELECT ENAME,JOB,SAL,
2 CASE JOB WHEN 'CLERK' THEN 1.5*SAL
3 WHEN 'SALESMAN' THEN 2.0*SAL
4 ELSE SAL END AS "RESAL"
5 FROM EMP;
SQL> SELECT ENAME,JOB,SAL,
2 DECODE (JOB,'CLERK',SAL*1.5,
3 'SALESMAN',SAL*2.0,
4 SAL) AS "RESAL"
5 FROM EMP;
两条SQL语句相同,工作为职员的薪水乘以1.5,销售员的薪水乘以2,其他不变,列名为resal
其中case函数中没有逗号,decode函数中用逗号代替when,then,else