oracle函数(1)

来源:互联网 发布:带数字的域名 编辑:程序博客网 时间:2024/05/20 14:28

1.数值型函数:

①.返回绝对值:

ABS(x)【功能】返回x的绝对值【参数】x,数字型表达式【返回】数字【示例】  select abs(100),abs(-100) from dual;

②.返回正负值:

ABS(x)【功能】返回x的绝对值【参数】x,数字型表达式【返回】数字【示例】  select abs(100),abs(-100) from dual;

③.返回较大的最小整数:

ceil(x)【功能】返回大于等于x的最小整数值【参数】x,数字型表达式【返回】数字【示例】  select ceil(3.1),ceil(2.8+1.3),ceil(0) from dual;返回4,5,0

④.返回较小的最大整数:

floor(x)【功能】返回小于等于x的最大整数值【参数】x,数字型表达式【返回】数字【示例】  select floor(3.1),floor(2.8+1.3),floor(0) from dual;返回4,5,0
⑤.返回四舍五入后的值:

round(x[,y])【功能】返回四舍五入后的值【参数】x,y,数字型表达式,如果y不为整数则截取y整数部分,如果y>0则四舍五入为y位小数,如果y小于0则四舍五入到小数点向左第y位。【返回】数字【示例】  select round(5555.6666,2.1),round(5555.6666,-2.6),round(5555.6666) from dual;返回:   5555.67     ,    5600    ,    5556


⑥.返回截取后的值:

trunc(x[,y])【功能】返回x按精度y截取后的值【参数】x,y,数字型表达式,如果y不为整数则截取y整数部分,如果y>0则截取到y位小数,如果y小于0则截取到小数点向左第y位,小数前其它数据用0表示。【返回】数字【示例】  select trunc(5555.66666,2.1),trunc(5555.66666,-2.6),trunc(5555.033333)  from dual;返回:5555.66                    5500               5555

2.字符型函数:

①.连接两个字符串:

CONCAT(c1,c2)【功能】连接两个字符串【参数】c1,c2 字符型表达式【返回】字符型同:c1||c2【示例】 select concat('010-','88888888')||'转23' 高乾竞电话 from dual;高乾竞电话----------------010-88888888转23

②.替换子字符:

TRANSLATE(c1,c2,c3)【功能】将字符表达式值中,指定字符替换为新字符【说明】多字节符(汉字、全角符等),按1个字符计算【参数】c1   希望被替换的字符或变量c2   查询原始的字符集c3   替换新的字符集,将c2对应顺序字符,替换为c3对应顺序字符如果c3长度大于c2,则c3长出后面的字符无效如果c3长度小于c2,则c2长出后面的字符均替换为空(删除)如果c3长度为0,则返回空字符串。如果c2里字符重复,按首次位置为替换依据【返回】字符型【示例】select TRANSLATE('he love you','he','i'),TRANSLATE('重庆的人','重庆的','上海男'),TRANSLATE('重庆的人','重庆的重庆','北京男士们'),TRANSLATE('重庆的人','重庆的重庆','1北京男士们'),TRANSLATE('重庆的人','1重庆的重庆','北京男士们') from dual;返回:i love you,上海男人,北京男人,1北京人,京男士人

③.返回字符串长度:

LENGTHC(c1).LENGTH2(c1).LENGTH4(c1)【功能】返回字符串的长度;【说明】多字节符(汉字、全角符等),按1个字符计算【参数】C1 字符串【返回】数值型【示例】 select length('高乾竞'),length('北京市海锭区'),length('北京TO_CHAR') from dual;Oracle中的字符函数中,有一类函数是求字符长度的函数,length、lengthB、lengthC、length2、length4几个函数中比较常用的是length、lengthB。他们的含义分别是:Length函数返回字符的个数,使用定义是给定的字符集来计算字符的个数LENGTHB给出该字符串的byteLENGTHC使用纯UnicodeLENGTH2使用UCS2LENGTH4使用UCS4下面是一些例子:Select length('你好') from dual;  2Select lengthB('你好'),lengthC('你好'),length2('你好'), length4('你好')  from dual;


3.日期函数:

①.返回系统当前的日期:

sysdate【功能】:返回当前日期。【参数】:没有参数,没有括号【返回】:日期【示例】select sysdate  hz from dual;返回:2008-11-5

②.返回指定月数后的日期:

add_months(d1,n1)【功能】:返回在日期d1基础上再加n1个月后新的日期。【参数】:d1,日期型,n1数字型【返回】:日期【示例】select sysdate,add_months(sysdate,3)  hz from dual;返回:2008-11-5,2009-2-5

③.返回本月最后一天的日期:

last_day(d1)【功能】:返回日期d1所在月份最后一天的日期。【参数】:d1,日期型【返回】:日期【示例】select sysdate,last_day(sysdate)  hz from dual;返回:2008-11-5,2008-11-30

④.返回当前会话时区:

SESSIONTIMEZONE【功能】:返回会话时区【参数】:没有参数,没有括号【返回】:字符型【示例】select dbtimezone,SESSIONTIMEZONE from dual;返回:+00:00   +08:00
⑤.四舍五入后的期间第一天:

round(d1[,c1])【功能】:给出日期d1按期间(参数c1)四舍五入后的期间的第一天日期(与数值四舍五入意思相近)【参数】:d1日期型,c1为字符型(参数),c1默认为j(即最近0点日期)【参数表】:c1对应的参数表:最近0点日期: 取消参数c1或j最近的星期日:day或dy或d最近月初日期:month或mon或mm或rm最近季日期:q最近年初日期:syear或year或yyyy或yyy或yy或y(多个y表示精度)最近世纪初日期:cc或scc【返回】:日期【示例】select sysdate 当时日期,round(sysdate) 最近0点日期,round(sysdate,'day') 最近星期日,round(sysdate,'month') 最近月初,round(sysdate,'q') 最近季初日期,round(sysdate,'year') 最近年初日期 from dual;



原创粉丝点击