签到成功

知道了

CNDBA社区CNDBA社区

Oracle 19c 中常用的函数

2022-02-14 20:43 2326 0 原创 Oracle 19c
作者: dave

在数据库开发中,经常会使用一些函数来处理数据。 数据库本身也会自带一些内置函数,程序员也可以根据自己的需要编写特定逻辑的函数。

在官方手里里有详细的罗列Oracle 自带的函数,链接如下:

https://docs.oracle.com/en/database/oracle/oracle-database/21/sqlqr/SQL-Functions.html
https://docs.oracle.com/en/database/oracle/oracle-database/21/sqlrf/Functions.html

内置函数比较多,这里列举几个常用的函数。

1.nvl(expression1, expression2)

函数作用:从两个表达式中返回一个非null值http://www.cndba.cn/dave/article/106663

用例:

select nvl(father_name, mother_name) parent_name from ustc where student_id = ‘12345’

如果expression1的值非空,优先取expression1的值;
如果expression1的值空且expression2的值非空,则取expression2的值;
如果expression1和expression2均为空,则结果为NULL

2. decode(field_name, value1, new_value1, value2, new_value2, default_value)

函数作用:类似if…else…语句块,针对某个字段,如果它的值为value1,则转换为newValue1,如果值为value2,则转换为newValue2,其他情况显示默认值

用例:

select decode(id,’1’,’A’,’2’,’B’,id) from A;

注意:

decode(field_name, value1, new_value1, value2, new_value2, default_value)其中的value1,newValue1等可以是一个表达式

3. row_number(order by field_name)

函数作用:将数据集按照某个字段排序,并产生序号字段
用例:

select row_number() over(order by name) no,id,name from a;

4. to_date(source_string, formater_string)

函数作用:将字符串转换为日期类型

用例:

select to_date(‘20220214’,’yyyyMMdd’) from dual;

注意:

‘yyyyMMdd’,’yyyymmdd’,’yyyy-MM-dd’,’yyyy-mm-dd’都可以

5. to_char()

函数作用:将其他类型转换为字符串类型

用例1:http://www.cndba.cn/dave/article/106663

select to_char(sysdate, ‘yyyymmdd’) from dual

用例2:

select to_char(99, ‘fm999.00’) from dual

http://www.cndba.cn/dave/article/106663

注意:http://www.cndba.cn/dave/article/106663

用例1中还有很多其他的日期格式,如yyyy,mm,dd,D,DD,DDD等
用例2中fm,9,0都有不同的含义,如下表所示

字符标志和含义:

9:如果存在数字则显示数字,不存在则显示空格
0:如果存在数字则显示数字,不存在则显示0,即占位符
fm:删除因为9带来的空格

http://www.cndba.cn/dave/article/106663

6. wm_concat

函数作用:行转列,将多行查询结果聚合到一行的某一列中
用例:

select wm_concat(distinct name) from student

7. listagg() within group(order by field_name) over(partition by field_name)

函数作用:同wm_concat,oracle 12c以后版本建议使用listagg() 代替wm_concat 函数。

用例:

select listagg(distinct name) within group(order by name desc) from student

8. concat(expression1, expression2)

函数作用:字符串拼接函数http://www.cndba.cn/dave/article/106663

用例:

select concat(‘left’, ‘Right’) from dual

注意:

也可以利用 || 进行拼接,select ‘a’||’b’ from dual

9. sys_guid()

函数作用:产生并返回一个全球唯一的标识符(原始值)由16个字节组成,32个字符

用例:

select sys_guid() from dual;

注意:

经常用来做表的主键

10. over(partition by field_name, order by field_name)

函数作用:over函数是一个分析函数,和聚合函数搭配在一起使用可以简洁代码

用例:

select name, job, sal, deptno,
sum(sal) over(partition by deptno) sum_sal, —统计某组中的总计值
avg(sal) over(partition by deptno) avg_sal, —统计某组中的平均值
from emp;

注意:按照以前的写法先进分组统计产生临时表关联原表才可以取到其他信息,现在则不需要了

通常和max(),min(),avg(),sum()等聚合函数一起使用

11. nlssort

函数作用:提供简体中文的特殊排序

用例:

select from student order by nlssort(name, ‘nls_sort = schinese_pinyin_m’) —拼音
select
from team order by nlssort(name, ‘nls_sort = schinese_stroke_m’) —笔画
select * from team order by nlssort(name, ‘nls_sort = schinese_radical_m’) —部首

12. trunc

函数作用:是截取日期或数字,根据规则返回指定的值
用例1:

select trunc(sysdate, ‘yyyy’) from dual

用例2:

select trunc(126.56, 0) from dual

注意:

用例1还有其他规则代表不同的含义

规则和含义:

mm:返回当月第一天
yy:返回当年第一天
dd:返回当前年月日
yyyy:返回当年第一天
d:返回当前星期的第一天

用例2还有其他规则代表不同含义http://www.cndba.cn/dave/article/106663

0:默认值,取下取整
正数a:保留小数点后面a位小数,其他的抹掉,如果a比小数点后的位数多,则保留原值
负数b:小数点后面的全部去掉,小数点向左移动abs(b)位,用0代替被抹掉的数字,如果所有数字都被抹掉,则返回0

13. rank() over(partition by field_name order by field_name)

函数作用:让返回结果根据分区和排序字段产生排名关系

用例:

select rank() over(partition by birthday order by score), s.* from student s;

注意:

dense_rank()用法和rank()一样,区别在于排名是否跳跃

14. substr(source, start [,length])

函数作用:截取字符串

用例:

select substr(‘abcde’, 2, 3) from dual

注意:

oracle字符串索引从1开始

15. replace(field_name, sub_str, replace_str)

函数作用:将指定的字符串替换为指定的字符串

用例:

select replace(name, ‘hello’, ‘world’) from student;

16. trim

函数作用:去掉左右两端的空白字符

用例:

select trim(‘ dsf ‘) from dual;

注意:

仅去掉左边空白字符用ltrim,仅去掉右边空白字符用rtrim

17. sign

函数作用:取数字n的符号,大于0返回1, 小于0返回-1, 等于0返回0http://www.cndba.cn/dave/article/106663

用例:http://www.cndba.cn/dave/article/106663

select sign(50),sign(-100),sign(0) from dual;

18. round(number[,decimal])

函数作用:对数字n进行四舍五入处理,保留decimal位小数

http://www.cndba.cn/dave/article/106663

用例:

select round(123.34),round(123.51),round(123.56,1),round(123.34,-1) from dual;

19. coalesce(expression1,expression2…)

函数作用:返回表达式中第一个不为空的值,如果全为空则返回空值

用例:

select coalesce(null,3+5,4+6) value from dual;

版权声明:本文为博主原创文章,未经博主允许不得转载。

用户评论
* 以下用户言论只代表其个人观点,不代表CNDBA社区的观点或立场
dave

dave

关注

人的一生应该是这样度过的:当他回首往事的时候,他不会因为虚度年华而悔恨,也不会因为碌碌无为而羞耻;这样,在临死的时候,他就能够说:“我的整个生命和全部精力,都已经献给世界上最壮丽的事业....."

  • 2262
    原创
  • 3
    翻译
  • 579
    转载
  • 192
    评论
  • 访问:8093542次
  • 积分:4350
  • 等级:核心会员
  • 排名:第1名
精华文章
    最新问题
    查看更多+
    热门文章
      热门用户
      推荐用户
        Copyright © 2016 All Rights Reserved. Powered by CNDBA · 皖ICP备2022006297号-1·

        QQ交流群

        注册联系QQ