我的编程空间,编程开发者的网络收藏夹
学习永远不晚

Oracle函数-单行函数-转换函数、条件表达式

短信预约 -IT技能 免费直播动态提醒
省份

北京

  • 北京
  • 上海
  • 天津
  • 重庆
  • 河北
  • 山东
  • 辽宁
  • 黑龙江
  • 吉林
  • 甘肃
  • 青海
  • 河南
  • 江苏
  • 湖北
  • 湖南
  • 江西
  • 浙江
  • 广东
  • 云南
  • 福建
  • 海南
  • 山西
  • 四川
  • 陕西
  • 贵州
  • 安徽
  • 广西
  • 内蒙
  • 西藏
  • 新疆
  • 宁夏
  • 兵团
手机号立即预约

请填写图片验证码后获取短信验证码

看不清楚,换张图片

免费获取短信验证码

Oracle函数-单行函数-转换函数、条件表达式

Oracle函数-单行函数-转换函数、条件表达式

单行函数

============================================================

特点:

每行返回一个结果,输入输出存在一一对应的关系

能嵌套使用 ,一个函数的输出能做另外一个函数的输入 如:select lowner(upper('aa')) from dual;

传入的变量可以是列的值,也可以是表达式。 如 select lower(ename) from emp;


============================================================

Oracle函数-单行函数-转换函数、条件表达式

转换函数:

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 hh34: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; 



免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

Oracle函数-单行函数-转换函数、条件表达式

下载Word文档到电脑,方便收藏和打印~

下载Word文档

猜你喜欢

mysql行列转换函数

摘要: mysql行列转换函数提供方法在行和列之间转换数据,用于数据分析和报表生成。其主要函数包括:pivot: 将行数据转换为列数据,语法:pivot ( sum(value_to_sum) for column_to_group_by
mysql行列转换函数
2024-08-01

[学习笔记] Oracle字符串函数、日期函数、数值函数、转换函数、聚合函数

函数单行函数:对一行数据进行操作的函数,如字符串函数、数值函数、转换函数、日期函数等。聚合函数:同时对多行数据进行操作,如求和函数等。字符串函数函数说明ASCII(X)求字符X的ASCII码CHR(X)求ASCII码对应的字符LENGTH(X)求字符串X的字符
[学习笔记] Oracle字符串函数、日期函数、数值函数、转换函数、聚合函数
2020-05-29

【Kotlin】Kotlin 函数总结 ( 具名函数 | 匿名函数 | Lambda 表达式 | 闭包 | 内联函数 | 函数引用 )

文章目录 一、函数头声明二、函数参数1、默认参数值2、具名参数 三、Unit 函数四、TODO 函数抛出异常返回 Nothing 类型五、反引号函数名六、匿名函数七、匿名函数的函数类型八、匿名函数的隐式返回九、匿名函数参数十、
2023-08-19

如何用 C++ lambda 表达式替换函数指针?

用 lambda 表达式替换函数指针可提升可读性、减少样板代码并提高重用性。具体而言,lambda 表达式采用以下语法:[capture list](parameter list) -> return type { body},并可用于对向
如何用 C++ lambda 表达式替换函数指针?
2024-04-17

Oracle中转换函数有哪些

这篇文章主要为大家展示了“Oracle中转换函数有哪些”,内容简而易懂,条理清晰,希望能够帮助大家解决疑惑,下面让小编带领大家一起研究并学习一下“Oracle中转换函数有哪些”这篇文章吧。转换函数 TO_CHAR函数将数据转换为字
2023-06-03

编程热搜

目录