oracle常用函数

 

1.sign
sign函数是根据给的数为正数,就返回1,0返回0,负数返回-1。需要注意sign(这个括号里面只能是个字段),在括号中写个子查询直接就报错了!

2.decode
用法:
decode(条件,值1,返回值1,值2,返回值2,…值n,返回值n,缺省值)

select decode(PROBLEM_LEVEL,1,'一般',2,'较大',3,'重大')as PROBLEM_LEVEL from accident //效果: 如果PROBLEM_LEVEL是2,查出来就是较大

3.tochar和todate

日期格式参数含义说明:
D 一周中的星期几
DAY 天的名字,使用空格填充到9个字符
DD 月中的第几天
DDD 年中的第几天
DY 天的简写名
IW ISO标准的年中的第几周
IYYY ISO标准的四位年份
YYYY 四位年份
YYY,YY,Y 年份的最后三位,两位,一位
HH 小时,按12小时计
HH24 小时,按24小时计
MI 分
SS 秒
MM 月
Mon 月份的简写
Month 月份的全名
W 该月的第几个星期
WW 年中的第几个星期

tochar用法:(把当前值转成字符串类型
 select sysdate,to_char(sysdate,'yyyy-mm-dd')from dual;
 select sysdate,to_char(sysdate,'yyyy/mm/dd')from dual;
 select sysdate,to_char(sysdate,'yyyymmdd')from dual;
 select sysdate,to_char(sysdate,'yyyymmdd hh24:mi:ss')from dual;

结果:

  1. 2017/6/15 17:07:24 2017-06-15

  2. 2017/6/15 17:07:25 2017/06/15

  3. 2017/6/15 17:07:25 20170615

  4. 2017/6/15 17:07:25 20170615 17:07:25

用to_char()可以得到日期中的年、月、日、时、分

 select sysdate,to_char(sysdate,'yyyy')from dual;
 select sysdate,to_char(sysdate,'mm')from dual;
 select sysdate,to_char(sysdate,'hh24')from dual;
 select sysdate,to_char(sysdate,'mi')from dual;

结果:

  1. 2017/6/15 17:09:14 2017

  2. 2017/6/15 17:09:14 06

  3. 2017/6/15 17:09:14 17

  4. 2017/6/15 17:09:14 09

todate

select to_date(’2003-10-17 21:15:37’,’yyyy-mm-dd hh24:mi:ss’) from dual
具体用法和上面的to_char差不多

4.trunk

格式:trunc(number,[decimals])

  • number   : 为必要参数,是输入的一个数值
  • decimals :参数可忽略,是要截取的位数,缺省时表示截掉小数点后边的值。

select trunc(12345.6789,0)  from  dual  --返回结果为12345 --第二个参数省略,相当于0
 
select trunc(12345.6789,0)  from  dual  --返回结果为12345 --截取0位小数==去除小数
 

select trunc(12345.6789,1)  from  dual  --返回结果为12345.6    --截取一位小数
 
select trunc(12345.6789,2)  from  dual  --返回结果为12345.67
 
select trunc(12345.6789,5)  from  dual  --返回结果为12345.6789

select trunc(12345.6789,-1)  from  dual  --返回结果为12340,-1相当于整数位截取一位,这里的截取是把数值直接变为0,不会去截取位数,更不会四舍五入
 

select trunc(12345.6789,-2)  from  dual  --返回结果为12300
 

select trunc(12345.6789,-3)  from  dual  --返回结果为12000    
 

select trunc(12345.6789,-4)  from  dual  --返回结果为10000
 

select trunc(12345.6789,-5)  from  dual  --返回结果为0

trunc(date,[format])

  • date     :为必要参数,是输入的一个date日期值
  • format  :参数可忽略,是日期格式

select trunc(to_date('2022/07/21','YYYY/MM/DD')) from dual

 

 

5.to_number()


to_number()函数是oracle中常用的类型转换函数之一,是将一些处理过的按一定格式编排过的字符串变回数值型的格式。我在展示long类型的id,需要使用这个,不然太长会按照科学计数法展示
1、to_number()函数可以将char或varchar2类型的string转换为一个number类型的数值;

2、需要注意的是,被转换的字符串必须符合数值类型格式,如果被转换的字符串不符合数值型格式,Oracle将抛出错误提示;

3、to_number和to_char恰好是两个相反的函数;
 

(1)to_number(varchar2 or char,'格式')

select to_number('000012134') from dual;  
select to_number('88877') from dual;  
(2)如果数字在格式范围内的话,就是正确的,否则就是错误的;如:

select to_number('$12345.678', '$999999.99') from dual;  
select to_number('$12345.678', '$999999.999') from dual;  
(3)可以用来实现进制转换;16进制转换为10进制:

select to_number('19f','xxx') from dual;  
select to_number('f','xx') from dual;  
 

 6.窗口函数,row number() over()比较常用

以上部分内容来自:

oracle数据库常用的函数总结_薄荷味脑花的博客-CSDN博客_oracle数据库常用函数

Oracle trunc()函数详解_睡竹的博客-CSDN博客_oracle trunc

oracle常用函数详解(详细)_u011955534的博客-CSDN博客_oracle 常用的函数

记在csdn上,便于复习

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

后季暖

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值