百度360必应搜狗淘宝本站头条
当前位置:网站首页 > 技术资源 > 正文

数据库篇-oracle函数 oracle函数大全及举例

lipiwang 2024-10-18 09:38 9 浏览 0 评论

1.round

例子:

select round(23.4),round(23.45,1),

round(23.45,-1) from employees;

结果:23 23.5 20

2.trunc 取整精度函数

select trunc(12.35) from dual

结果:12

3.ceil/floor 取整函数

例子:

select ceil(23.45),floor(23.45) from emp;

结果:24 23

4.计算函数

(1) abs 取绝对值

例子:

select abs(23.45),abs(-23),abs(0) from emp;

结果:23.45 23 0

(2) mod(m,n) 取余数

select mod(5,2) from emp 结果: 1

select mod(5,null) from emp 结果就是空

(3) power(m,n) 返回m的N次幂

select power(2,3) from emp;

(4) sqrt:求平方根

select sqrt(16) from emp 结果 4

5.聚合函数

(1)sum 求和函数

select sum(a.salary) from stuinfo a;

(2)count 统计函数

select count(*) from stuinfo a;

(3)avg 平均函数

select avg(a.salary) from stuinfo a;

(4)max 最大值函数

select max(a.salary) from stuinfo a;

(5)min 最小值函数

select min(a.salary) from stuinfo a;

6.字符函数

(1) upper 小写转大写

(2) lower 大写转小写

(3) initcap首字母大写

(4) substr (char,[m[,n]])获取子字符串函数

注:负号是从结尾往回数

select substr('abcde',2,3),substr('abced',2),

substr('abced',-2,1) from emp;

结果: bcd bcde e

(5) length获取字符串长度

select length('abc') from emp;

结果:3

(6) concat(char1,char2)字符串连接函数或者||

concat(char1,char2)

select concat('ab','cd') from emp;

和select 'ab' || 'cd' from emp;结果一样

(7) TRIM去除子串函数 (c2 from c1)

该函数表示从字符串c1中去除字符c2

select trim('a' from 'abcde') from emp;

结果: bcde

LTRIM(c1[,c2]):从c1中去除c2

selct ltrim('ababaa','a') from emp;

结果:babaa 结果是去除掉第一个a了

rtrim(c1[,c2]) 从尾部去除字符;

selct rtrim('ababaa','a') from emp;

结果:abab

TRIM(c1):去除左边空格

(8) 替换函数REPLACE(char,s_string[,r_string])

省略r_string用空格替换

例子:将a替换成大写的A

select replace('abcde','a','A') from emp;

结果 Abcde 要是不写‘A’就去掉a了;

替换ab:

select replace('abcde','ab','A') from emp;

结果 Acde 就是ab同时被换

(9) instr查找函数

在一个字符串中查找另外一个字符串

select instr('sdsdddssd','ds') from dual;

从第二位置查找,查找第二次出现ds的位置是多少。

select instr('sdsdddssd','ds',2,2) from dual;

7.日期函数:

(1) sysdate系统时间:

默认格式:DD-MON-RR

select sysdate from emp; --返回当前时间

(2) 日期操作add_months(date,i)

i可以是任何的整数 如果i 是负数 就相应的减去几个月

例子:在当前日期加上3个月或者减去3个月

select add_months(sysdate,3),

add_months(sysdate,-3) from emp;

结果:22-8月-15 22-2月 -15

(3) next_day(date,char) 星期几

下周一是哪天

select next_day(sysdate,'星期一') from emp;

(4) last_day(date) 返回所在月最后一天

select last_day(sysdat) from emp;

(5) MONTHS_BETWEEN(date1,date2)

表示两个日期之间相隔的月份差

select months_between('20-5月-15','10-1月-15‘)

from emp;

结果:4

(6) extract(date from datetime)

返回当前日期的年份

select extract(year from hire_date),

extract(month from hire_date),

extract(day from hire_date) from employees;

例子:

返回年份

select extract(year from sysdate) from emp;

返回月份

select extract(month from sysdate) from emp;

返回天

select extract(day from sysdate) from emp;

获取小时

select extract(hour from timestamp '2015-10-1 17:25:13')

from emp;

8.转换函数

(1) 日期转换成字符的函数to_char

to_char(date[,fmt[,params]])

参数说明:date:将要转换的日期 。

fmt: 转换的格式 params:日期的语言

日期转换日期的函数如下

格式: YY YYYY YEAR 年 。

MM MONTH 。 月

DD DAY 。 天

HH24 HH12 。 时

MI SS 。 分

例子:select

to_char(sysdate,'YYYY-MM-DD HH24:MI:SS')

FROM emp;

(2) 字符转换成日期的 to_date

to_date和to_cahr区别就是 to_date转换后的日期

格式跟系统一样,一般用to_char这样是可以自己

选择要什么样的格式,to_date: 03-9月-17

to_date(date[,fmt[,params]])

select

to_date('2015-05-22','YYY-MM-DD')

from emp;

一般结果会根据系统设置的一样

结果:03-9月-17

例子2:

查询2006年入职的员工信息日期是2006/1/16

select * from employees

where to_char(hire_date,'YYYY/MM/DD')

between '2006/01/01' and '2007/01/01';

select * from employees

where hire_date like '%06%';

(3) 数字转换成字符的函数

to_char(number[,fmt])

9:显示数字并忽略前面的0

0:显示数字,位数不足,用0补齐

.或D:显示小数点

,或G: 显示千位符

$:美元符号

S:加正负号(前后都可以)

例子:

select to_char(12345.678,'$99.999.999')

from emp;

结果:$12,345.678

select to_char(12345.678,'S99.999.999')

from emp;正负号:

结果:+12,345.678

(4) 字符转换成数字的函数

to_number(char,[,fmt])

例子:select to_number('$1000','$9999')

from emp;

结果:1000

9. 填充函数

左填充 lpad 右填充 rpad

select lpad('abcd',10,'*') 左,

rpad('abcd',10,'*') 右

from dual;

结果:

******abcd abcd******

10. NVL通用函数

(1) NVL(expr1,expr2)

如果oracle第一个参数为空那么显示第二个参数的值,

如果第一个参数的值不为空,则显示第一个参数本来

的值。

例如:

SQL> select ename,NVL(comm, -1) from dual;

(2) NVL2函数

如果该函数的第一个参数不为空那么显示第二个参数

的值,如果第一个参数的值为空,则显示第三个参数

的值.

SQL> select ename,NVL2(comm,-1,1)

from emp;

(3) NULLIF函数

NULLIF(exp1,expr2)函数

作用是如果exp1和exp2相等则返回空(NULL),

否则返回第一个值。

11. Coalesce函数

Coalese函数的作用是的NVL的函数有点相似,

其优势是有更多的选项。

格式如下:

Coalesce(expr1, expr2, expr3….. exprn)

含义:

返回表达式中第一个非空表达式

SELECT COALESCE(NULL,NULL,3,4,5)

FROM dual  

其返回结果为:3

如果所有自变量均为 NULL,则 COALESCE

返回 NULL 值。

12.wm_concat:字段合并函数

将一列以行的形式展现

原表name是:

a

b

c

d

转化后

select wm_concat(name) from dual;

结果a,b,c,d,e

把结果里的逗号替换成"|"

select replace(wm_concat(name),',','|')

from dual;

13.over分析函数

按部门“连续”求总和

sum(sal) over (partition by deptno order by ename) ;

按部门求总和

sum(sal) over (partition by deptno) ;

不按部门“连续”求总和

sum(sal) over (order by deptno,ename) ;

不按部门,求所有员工总和,效果等同于sum(sal)。

sum(sal) over ()

常用的分析函数如下所列:

row_number() over(partition by ... order by ...)

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

dense_rank() over(partition by ... order by ...)

count() over(partition by ... order by ...)

max() over(partition by ... order by ...)

min() over(partition by ... order by ...)

sum() over(partition by ... order by ...)

avg() over(partition by ... order by ...)

first_value() over(partition by ... order by ...)

last_value() over(partition by ... order by ...)

lag() over(partition by ... order by ...)

lead() over(partition by ... order by ...)

14.decode函数

select employee_id,

decode(sign(salary-17000),1,'优秀',0,'优秀',-1,

decode(sign(salary-6000),1,'良好',0,'良好',-1,

decode(sign(salary-4200),1,'及格',0,'及格',-1,'不及格')))

from employees;

相关推荐

一个简单便捷搭建个人知识库的开源项目(MDwiki)

这里我通过自动翻译软件,搬运总结MDwiki官网的部署和使用方法。第一步:下载编译好的后MDwiki文件,只有一个HTML文件“mdwiki.html”。第二步:在mdwiki.html同级目录创建“...

强大、简洁、快速、持续更新 PandaWiki新一代 AI 驱动的开源知识库

PandaWiki是什么PandaWiki是一款AI大模型驱动的开源知识库搭建系统,帮助你快速构建智能化的产品文档、技术文档、FAQ、博客系统,借助大模型的力量为你提供AI创作、AI问答...

DeepWiki-Open: 开源版Deepwiki,可自己构建github文档库

Deepwiki是Devin团队开发的github文档库,用户能免费使用,但代码不是开源,而DeepWiki-Open侧是开源版本的实现。DeepWiki-Open旨在为GitHub和GitLa...

最近爆火的wiki知识管理开源项目PandaWiki

项目介绍PandaWiki是一款AI大模型驱动的开源知识库搭建系统,帮助你快速构建智能化的产品文档、技术文档、FAQ、博客系统,借助大模型的力量为你提供AI创作、AI问答、AI搜索等...

轻量级开源wiki系统介绍(轻量开源论坛系统)

wiki系统有很多DokuWiki、MediaWiki、MinDoc等等都是开源的wiki系统。商业版的wiki,像很多企业在用的confluence等。今天我们讲的是一款轻量级且开源的文档管理系统:...

DNS解析错误要怎么处理(dns解析状态异常怎么办)

在互联网时代,网络已经成为人们生活和工作中不可或缺的一部分。然而,当遇到DNS解析错误时,原本畅通无阻的网络访问会突然陷入困境,让人感到十分困扰。DNS,即域名系统,它如同互联网的电话簿,将人们易于...

网页加载慢?这些方法让你秒开网页!

打开浏览器,信心满满地准备查资料、看视频或者追剧,却发现网页怎么都打不开!是不是瞬间感觉手足无措?别慌,这个问题其实挺常见,而且解决起来并没有你想象的那么复杂。今天就来聊聊网页打不开究竟是怎么回事,以...

windows11 常用CMD命令大全(windows11msdn)

Windows11中的命令提示符(CMD)是一个强大的工具,可以通过命令行执行各种系统操作和管理任务。以下是一些常用的CMD命令,按功能分类整理,供你参考:一、系统信息与状态systeminfo显...

电脑提示DNS服务器未响应怎么解决?

我们在使用电脑的时候经常会遇到各种各样的网络问题,例如最近就有Win11电脑用户在使用的时候遇到了DNS未响应的问题,遇到这种情况我们应该怎么解决呢?  方法一:刷新DNS缓存  1、打开运行(W...

宽带拨号错误 651 全解析:故障定位与修复方案

在使用PPPoE拨号连接互联网时,错误651提示「调制解调器或其他连接设备报告错误」,通常表明从用户终端到运营商机房的链路中存在异常。以下从硬件、系统、网络三层维度展开排查:一、故障成因分类图...

如何正确清除 DNS 缓存吗?(解决你访问延时 )

DNS缓存是一个临时数据库,用于存储有关以前的DNS查找的信息。换句话说,每当你访问网站时,你的操作系统和网络浏览器都会保留该域和相应IP地址的记录。这消除了对远程DNS服务器重复查询的...

网络配置命令:ipconfig和ifconfig,两者有啥区别?

在计算机网络的世界里,网络接口就像是连接你电脑和外部网络的桥梁,而网络配置则是确保这座桥梁稳固、通信顺畅的关键。提到网络配置工具,ipconfig和ifconfig绝对是两个绕不开的名字。它们一...

救急的命令 你会几个?(救急一下)

很多人都说小编是注册表狂魔,其实不完全是,小编常用的命令行才是重点。其实所谓的命令行都是当初DOS时代的标准操作方式,随着Windows不断演化,DOS的命令早已成为Windows的一部分了——开始菜...

电脑有网却访问不了GitHub原来是这样

当满心欢喜打开电脑,准备在GitHub这个“开源宝藏库”里挖掘点超酷的项目,却遭遇了网页无法访问的尴尬。看着屏幕上那令人无奈的提示,原本高涨的热情瞬间被泼了一盆冷水,是不是感觉世界都不美好了...

rockstargames更新慢| r星更新速度 怎么办 解决办法

rockstargames更新慢|r星更新速度怎么办解决办法说到RockstarGames,那可是游戏界的大佬,作品个顶个的经典。但话说回来,每当新内容更新时,那蜗牛般的下载速度,真是让人急得...

取消回复欢迎 发表评论: