oracle一:常用的函数详解

Oracle常用的函数

 

一、单行函数:

只处理单个行,并且为每行返回一个结果。

 

1.1、字符函数:

1、concat(str1,str2) 字符串拼接函数:
select concat('hello','world') from dual;

-- 等价于
select 'hello' || 'world' from dual;

 

2、initcap(str)将每个单词首字母大写,其他字母小写:
select initcap('hello world!') from dual; --返回结果为'Hello World!'

select initcap('HELLO WORLD!') from dual; --返回结果为'Hello World!'

 

3、instr(x,find_string[,start][,occurrence])返回指定字符串在某字符串中的位置,可以指定搜索的开始位置和返回第几次搜索出来的结果:
select instr('Hello World!','o') from dual;--从1位置开始搜索,返回第一次出现的o的位置,结果为5
select instr('Hello World!','o',6) from dual;--从6位置开始搜索,返回第一次出现的o的位置,结果为8
select instr('Hello World!','o',1,2) from dual;--从1位置开始搜索,返回第二次出现o的位置,结果为8

 

4、length(str)返回表达式中的字符数:
select length('Hello World!') from dual;--返回结果为12
select length('张三') from dual;--返回结果为2

 

5、lower(str)将字符串转换为小写:
select lower('Hello World!') from dual;

 

6、lengthb(str)返回表达式中的字节数
select lengthb('Hello World!') from dual;--返回结果为12
select lengthb('张三') from dual;--返回结果为6

 

7、upper(str)将字符串转换为大写:
select upper('Hello World!') from dual;

 

8、lpad(str,width[,pad_string])当字符串长度不够时,左填充补齐,可以指定补齐时用什么字符补齐,若不指定,则以空格补齐:
select lpad('Hello World!',20) from dual;--返回结果为' Hello World!'
select lpad('Hello World!',20,'*') from dual;--返回结果为'********Hello World!'

 

9、rpad(str,width[,pad_string])当字符串长度不够时,右填充补齐,原理同左填充
select rpad('Hello World!',20) from dual;--返回结果为'Hello World! '
select rpad('Hello World!',20,'*+') from dual;--返回结果为'Hello World!*+*+*+*+'

 

10、ltrim(x[,trim_string])从字符串左侧去除指定的所有字符串,若没有指定去除的字符串,则默认去除左侧空白符
select ltrim(' Hello World! ') from dual;--返回结果为'Hello World! '
select ltrim('***+*Hello World!***+*','*+') from dual;--返回结果为'Hello World!***+*'

 

11、rtrim(x[,trim_string])从字符串右侧去除指定的所有字符串,原理同ltrim()
select rtrim(' Hello World! ') from dual;--返回结果为' Hello World!'
select rtrim('***+*Hello World!***+*','*+') from dual;--返回结果为'***+*Hello World!'

 

12、trim(trim_string from x)从字符串两侧去除指定的所有字符串 注意,ltrim()和rtrim()的截取集可以是多个字符,但trim的截取集只能有一个字符:
select trim('*' from '***+*Hello World!***+*') from dual;-- 返回 +*Hello World!***+
select trim('   ***+*Hello World!***+*   ') from dual;  -- 返回***+*Hello World!***+*,去除两端的空白
select trim('+*' from '***+*Hello World!***+*') from dual;-- 错误

 

13、nvl(x,value)将一个NULL转换为另外一个值,如果x为NULL,则返回value,否则返回x值本身:
insert into student values(7,'猪猪',default,NULL);
select nvl(address,'北京市') from student;

 

14、nvl2(x,value1,value2),如果x不为NULL,返回value1,否则,返回value2:
select nvl2(address,'有地址','无地址') from student;

 

15、replace(x,search_string,replace_string),从字符串x中搜索search_string字符串,并使用replace_string字符串替换。并不会修改数据库中原始值
select replace('Hello World!','o','HA') from dual;

 

16、substr(x,start[,length])返回字符串中的指定的字符,这些字符从字符串的第start个位置开始,长度为length个字符;如果start是负数,则从x字符串的末尾开始算起;如果length省略,则将返回一直到字符串末尾的所有字符:
select substr('Hello World',3) from dual; --返回结果为'llo World'
select substr('Hello World',-3) from dual;--返回结果为'rld'
select substr('Hello World',3,2) from dual;--返回结果为'll'
select substr('Hello World',-7,4) from dual;--返回结果为'o Wo'

 
 
 

1.2、数值函数:

1、abs(value)返回value的绝对值:
select abs(-10) from dual;--返回结果为10

 

2、ceil(value)返回大于等于value的最小整数:

select ceil(2.3) from dual; --返回结果为3

 

3、floor(value)返回小于等于value的最大整数:
select floor(2.3) from dual; --返回结果为2

 

4、trunc(value,n)对value进行截断,如果n>0,保留n位小数;n<0,则保留-n位整数位;n=0,则去掉小数部分:
select trunc(555.666) from dual; --返回结果为555,不加n时默认去掉小数部分
select trunc(555.666,2) from dual;--返回结果为555.66
select trunc(555.666,-2) from dual;--返回结果为500

 

5、round(value,n)对value进行四舍五入,保存小数点右侧的n位。如果n省略的话,相当于n=0的情况:
select round(555.666) from dual;--返回结果为556,不加n时默认去掉小数部分
select round(555.666,2) from dual;--返回结果为555.67
select round(555.666,-2) from dual;--返回结果为600

 

注意:

1.trunc和round用法类似,只不过trunc是硬生生截取,并不进行四舍五入,而round进行截取时四舍五入;
2.都还可以对日期的截取,可以参考写的日期函数笔记。

 
 
 

1.3、转换函数:

将值从一种类型转换成另外一种类型,或者从一种格式转换为另外一种格式。

 

1、to_char(x[,format]):将x转化为字符串。 format为转换的格式,可以为数字格式或日期格式:
select to_char('12345.67') from dual; --返回结果为12345.67
select to_char('12345.67','99,999.99') from dual; --返回结果为12,345.67
select to_char(to_date('2021-03-26','yyyy-mm-dd')) from dual; --返回结果为26-3月 -21
select to_char(sysdate) from dual; --返回结果为26-3月 -21

 

2、to_number(x [, format]):将x转换为数字。可以指定format格式:
select to_number('970.13') + 25.5 from dual;-- 返回和:995.63
select to_number('-$12,345.67', '$99,999.99') from dual;-- 返回-12345.67

 

3、cast(x as type):将x转换为指定的兼容的数据库类型
  select cast(12345.67 as varchar2(10)),
     cast('05-7月-07' as date),
     cast(12345.678 as number(10,2)) 
  from dual;

 

4、to_date(x [,format]):将x字符串转换为日期:
select to_date('2012-3-15','YYYY-MM-DD') from dual;

 
 
 
 
 
 
 

二、聚合(多行函数、分组函数、组函数)函数:

 
操作多行数据,并返回一个结果。比如 SUM。
 
 

2.1、常用聚合函数:

1、avg(x):返回x的平均值:
select avg(grade) from sc;

 

2、count(x):返回统计的行数
select count(name) from sc;

 

3、max(x):返回x的最大值
select max(grade) from sc;

 

4、min(x):返回x的最小值
select min(grade) from sc;

 

5、sum(x):返回x的总计值
select sum(grade) from sc;

 
 
 

2.2、聚合函数的应用:

  • 一般分组中会使用到聚合函数;
  • 对分组后的行使用聚集函数,聚集函数会统计每组中的值,对于每组分别统计后返回一个值。

 
 
 

2.3、注意:

  1. 分组时select子句后边的列名必须与group by子句后的列名一致,除非是聚合函数;即:group by后面的字段是select后面所有的非聚合的字段。

select deptno,avg(sal) from EMP;--错误,因为deptno不是聚集函数,也不是group by后面跟的列名
select deptno,avg(sal) from EMP group by deptno ;--正确

 
2. 不能使用聚集函数作为WHERE子句的筛选条件。


select deptno from emp where avg(sal)>1000;--错误

 
3. 分组后,需要使用条件进行筛选,则使用having过滤分组后的行,不能使用where,where只能放在group by前面。

select deptno, avg(sal) from emp where deptno<>10 
group by deptno 
having avg(sal) > 900;
  •  
     
     
     
     
     

三、trunc函数的应用详解:

         用于截取时间或者数值,返回指定的值。

 

1、截取时间:

	  select  trunc(to_date('2020-02-01 1:00:00','YYYY-MM-DD HH:MI:SS'),'yyyy') from   dual ;--返回当年第一天
	  select  trunc(to_date('2020-02-01 1:00:00','YYYY-MM-DD HH:MI:SS'),'mm') from   dual ; --返回当月第一天
	  select  trunc(to_date('2020-02-10 1:00:00','YYYY-MM-DD HH:MI:SS'),'dd') from   dual ;--返回当前年月
	  select  trunc(to_date('2020-03-25 1:00:00','YYYY-MM-DD HH:MI:SS'),'d') from   dual ; --返回当前星期的第一天(星期一) 
	  select  trunc(to_date('2020-02-01 1:12:12','YYYY-MM-DD HH:MI:SS'),'hh') from   dual ;--返回当前日期截取到小时,分秒补0
	  select  trunc(to_date('2020-02-01 1:12:12','YYYY-MM-DD HH:MI:SS'),'mi') from   dual ;--返回当前日期截取到分,秒补0

 

2、截取数值:

  • 语法:trunc(number,decimals);

  • number:指需要截取的数字;

  • decimals :截取的格式(精度);

  • TRUNC()函数截取时不进行四舍五入。

    select trunc(122.555) from dual;-- 默认取整
    select trunc(122.555,2) from dual; -- 截取两位小数
    select trunc(122.555,-2) from dual; --负数表示从小数点左边开始截取2位
    select trunc(123.458) from dual --123
    select trunc(123.458,0) from dual --123
    select trunc(123.458,1) from dual --123.4
    select trunc(123.458,-1) from dual --120
    select trunc(123.458,-4) from dual --0
    select trunc(123.458,4) from dual  --123.458
    select trunc(123) from dual  --123
    select trunc(123,1) from dual --123
    select trunc(123,-1) from dual --120
    

 
 
 

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值