数据库篇-oracle函数,数据库篇-oracle函数
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 '%';
(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;
,免责声明:本文仅代表文章作者的个人观点,与本站无关。其原创性、真实性以及文中陈述文字和内容未经本站证实,对本文以及其中全部或者部分内容文字的真实性、完整性和原创性本站不作任何保证或承诺,请读者仅作参考,并自行核实相关内容。文章投诉邮箱:anhduc.ph@yahoo.com