4、转换函数和条件表达式

四、转换函数与条件表达式

转换函数: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

 

 

 

  • 4
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值