oracle常用的函数

decode()函数:
用法:(条件,值1,返回值1,值2,返回值2,…值n,返回值n,缺省值)
相当于case when方法:

IF条件=1THEN
    RETURN(返回值1)
ELSIF条件=2THEN
    RETURN(返回值2)
......
ELSIF条件=值nTHEN
    RETURN(返回值n)
ELSE
    RETURN(缺省值)
ENDIF 

to_date(): 将字符类型按照一定格式转化为日期类型

select to_date(2003-10-17 21:15:37,‘yyyy-mm-dd hh24:mi:ss’) from dual

to_char(): 将日期按照一定格式转换为字符类型

 select to_char(sysdate,’‘yyyy-mm-dd hh24:mi:ss’’) time from dual;

LAST_DAY(d) 函数:
返回指定日期当月的最后一天

SELECT SYSDATE,last_day(SYSDATE) FROM dual;

add_months 函数:
主要是对日期函数进行操作,在数据查询的过程中进行日期的按月增加,其形式为:
add_months(date,int);其中第一个参数为日期,第二个为按月增加的幅度,例如:

add_months (sysdate,2):就是当前日期的两个月之后的时间。

查询当前时间1个月以前的时间:

select add_months(sysdate,-1) from dual;

查询当前时间一个月以后的时间:

select add_months(sysdate,1) from dual;

sum函数:
求和

SELECT SUM(column_name) FROM table_name

count函数:
计算条数
计算count的列有值的信息条数 列为空不记录

select count(column_name) from table_name;

avg函数:
平均值

select avg(column_name) from table_name;

max函数:
最大值

SELECT MAX(column_name) FROM table_name;

min函数:
最小值

SELECT MIN(column_name) FROM table_name;

UPPER函数:
把小写英文字符转换成大写

SELECT UPPER(column_name) FROM table_name;

lower函数:
把大写英文字符转换为小写

SELECT lower(column_name) FROM table_name;

round函数:
#四舍五入到小数点以后xxx位

SELECT ROUND(column_name,decimals) FROM table_name;

TRUNC(x[,y])函数

直接截取,不四舍五入

在缺省 y 时,默认 y=0;比如:TRUNC (3.56)=3。
Y是正整数,就是四舍五入到小数点后 y 位。TRUNC (5.654,2)=5.65。
y 是负整数,四舍五入到小数点左边|y|位。TRUNC (351.654,-2)=300

substr函数:
截取字符串 column_name:字段名 start:开始位数 len:截取的长度位数

SELECT substr(column_name,start,len) FROM table_name;

其中start代表从第几个字符开始,len代表要截取的字符串长度;

length函数():

SELECT length(column_name) FROM table_name;

nvl函数():
返回值类型可以为字符型、日期型、日期时间型、数值型、货币型、逻辑型或nul值…
NVL(E1, E2)的功能为:
如果E1为NULL,则函数返回E2,否则返回E1本身。
但此函数有一定局限,所以就有了NVL2函数。

拓展:NVL2函数:
Oracle/PLSQL中的一个函数,Oracle在NVL函数的功能上扩展,提供了NVL2函数。
NVL2(E1, E2, E3)的功能为:
如果E1为NULL,则函数返回E3,若E1不为null,则返回E2。

replace()函数:
replace(x,old,new) 在x中查找old,并替换成new

SELECT REPLACE('ABCDE','CD','AAA')FROM dual;
运行结果:
ABAAAE

Trim()函数:
TRIM([Trim_str from] x) 把x两边截去Trim_str 字符串,缺省截去空格

SELECT TRIM('='FROM'=Hello=') FROM dual;      
运行结果:
Hello

ASCII(X)函数:
#返回x的ASCII码值

SELECT ASCII('a') FROM dual;
运行结果:
运行结果:
97

LENGTH(X)函数:

#返回x的长度
SELECT LENGTH('Hello') FROM dual;
运行结果:
5

本文章仅供个人学习使用,如有雷同,敬请谅解。

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值