分析函数,用于统计排名

语法:函数名() over(order by 排序字段 asc | desc)

row_number() 无论值是否相等,生成连续的行号

-- 1,2,3,4,

select ename,sal,row_number() over (order by sal desc) 名次 from emp;

dense_rank() 如果值相等,则排名相同,排名仍连续

--1,2,2,3,4,5

select ename,sal,dense_rank() over (order by sal desc) 名次 from emp;

rank() 如果值相等,则排名相同,排名不连续

select ename,sal,rank() over (order by sal desc) 名次 from emp;

select ,case when 条件 then '结果' else '' ,from 表

select ename,sal, case

when sal<=1000 then '★'

when sal<=2000 then '★★'

when sal<=3000 then '★★★'

when sal<=4000 then '★★★★'

when sal<=5000 then '★★★★★'

end 等级 from emp;

单行函数(标量函数),1行数据返回1个结果

日期函数

sysdate 返回系统当前时间

--dual 专业用来做运算的表 只有一行一列

select sysdate from dual;

select 1+2+3+4*5*5/7 from dual;

用于加/减,关系运算

select sysdate 当前时间 from dual

--几天之后

select sysdate+3 from dual

--几天之前

select sysdate-3 from dual

--间隔天数

距离年底还有多少天

select to_date('2016-12-31','yyyy-mm-dd')-sysdate from dual

--查询1982年1月1日之后入职的员工

select * from emp

where hiredate>to_date('19820101','yyyymmdd');

months_between(d1,d2) 返回指定日期之间的月份间隔

add_months(d,num) 返回给指定日期加上整数个月后的新日期

--查询入职时间和转正时间 [3个月转正]

last_day(d) 返回指定日期当月的最后1天

--查询每月最后1天入职的员工

--查询每月倒数第3天入职的员工

字符函数:字符串下标从1开始,0也表示第1位

length(str) 返回字符串的长度

select length('abc123456') from dual;

select ename,length(ename) from emp;

substr(str,index)/substr(str,index,length)

select substr('huwen@163.com',6) from dual; --下标从1开始

--java 下标0开始 oracle 下标1 开始

select substr('huwen@163.com',7,3) from dual;

--java 第1才是 下标,第2个参数还是下标

--oracle 第1个是下标 第2个长度

instr(str1,str2) 返回str1中str2出现的下标

--instr就相当于java indexOf()

select instr('yyyy@163.com','@') from dual;

select '&name' from dual

--'&xxx' 表示接收用户输入

select substr('&email',1,instr('&email','@')-1) from dual;

select substr('&email',instr('&email','@')+1) from dual;

转换函数

to_char(d)/to_char(d,fmt) 日期>>字符

--转默认格式的字符串

select to_char(sysdate) from dual;

select to_char(sysdate,'yyyy"年"mm"月"yy"日"') from dual

--转指定格式的字符串:yyyy,mm,dd,hh/hh24,mi,ss,day

select to_char(sysdate,'day') from dual;

select to_char(sysdate,'yyyy/mm/dd') from dual;

select to_char(sysdate,'hh24:mi:ss') from dual;

select to_char(sysdate,'yyyy-mm-dd hh24:mi:ss day') from dual;

select to_char(sysdate,'fmyyyy"年"mm"月"dd"日" day') from dual;

--fm 表示去掉日期前缀0

select hiredate ,to_char(hiredate,'yyyy') from emp;

to_date(str)/to_date(str,fmt) 字符>>日期

--默认格式

select to_date('1-10月-12')-sysdate from dual;

--指定格式

select to_date('2012-10-1','yyyy-mm-dd')-sysdate from dual;

select to_date('2012-10-1 15:50:00','yyyy-mm-dd hh24:mi:ss')-sysdate from dual;

to_char(num,fmt) 数字>>字符,用于货币的显示

select to_char(10000,'9,999,999.99') from dual;

select ename,sal,

to_char(sal,'$9,999.99') 美元,

to_char(sal,'C9,999.99') 人民币,

to_char(sal,'L9,999.99') 本土 from emp;

数学函数

mod(n1,n2) 返回n1除以n2的余数

select mod(7,2) from dual -- 7%2

ceil(num) 返回大于等于该数的最小整数--向上取整

select ceil(4.0001) from dual

floor(num) 返回小于等于该数的最大整数--向下取整

select floor(4.99999) from dual

round(num)/round(num,s) 四舍五入,s表示小数位数

select round(4.5) from dual;

select round(4.4) from dual;

select round(-11.5) from dual; --java里面是-11 这里-12

--保留3位小数

select round(3.141596,3) from dual;

trunc(num)/trunc(num,s) 截断数字,直接舍去

select trunc(4.7) from dual;

select trunc(4.79,1) from dual; --保留一位小数

其他函数

nvl(exp1,exp2) 空值替换函数

含义:如果表达式exp1为null,则使用表达式exp2代替

--Oracle排序时,将空值null理解为最大

select ename,sal,comm from emp order by comm desc

select * from emp order by nvl(comm,0) desc,sal desc;

--表达式计算时,如果包含空值null,则返回null

select ename,sal,comm,(sal+nvl(comm,0))*12 年薪 from emp;

decode() 相当于case..when..语句

case when 条件 then 结果 -- 相当于java if else if

decode 就相当于switch 可以判断相等

select ename,deptno,

decode(deptno,10,'技术部',20,'销售部',30,'管理层')

from emp;

select ename,deptno,

decode(deptno,10,'AAA',20,'BBB',30,'CCC') 部门 from emp;

关于oracle数据库(10)函数的更多相关文章

  1. Oracle数据库DECODE函数的使用.

    decode函数是Oracle数据库独有的. 语法为: decode(条件,值1,返回值1,值2,返回值2,...值n,返回值n,缺省值) 例子:select decode(sign(变量1-变量2) ...

  2. Oracle数据库to_date函数注意事项

    使用PL/SQL连接到Oracle数据库服务器,执行一条update语句: update pjnl set transtime = to_date('2015-05-14 12:13:20','yyy ...

  3. Oracle数据库--SQL函数

    Oracle SQL函数  1.ASCII返回与指定的字符对应的十进制数;SQL> select ascii('A') A,ascii('a') a,ascii('0') zero,ascii( ...

  4. Oracle数据库有用函数

    有用函数 DECODE 语法例如以下: DECODE(value, if1, then1, if2,then2,if3,then3, . . . else )  Value 代表某个表的不论什么类型的 ...

  5. Oracle数据库的函数

    一.字符函数upper和lower (1).upper和lower upper把小写的字符转换成大小的字符 ,lower把大写字符变成小写字符 . select upper('yes') from d ...

  6. Mysql和Oracle数据库concat()函数

    一.函数的使用参数不同 Mysql支持多个字符串拼接: CONCAT(str1,str2,-) Oralce只支持两个字符串的拼接,若想拼接多个字符串可以嵌套使用concat CONCAT(str1, ...

  7. Oracle数据库常用函数

    Oracle常用函数: 20.COS返回一个给定数字的余弦SQL> select cos(-3.1415927) from dual;COS(-3.1415927)--------------- ...

  8. Oracle数据库over函数的使用

    转自:  https://blog.csdn.net/a1065423444/article/details/75635611 over()函数写法over(partition by expr2 or ...

  9. ORACLE 数据库 MOD 函数用法

    1.求2和1的余数. Select mod(2,1) from dual: 2能被1整除所以余数为0. 2.MOD(x,y)返回X除以Y的余数.如果Y是0,则返回X的值. Select mod(2,0 ...

  10. Oracle数据库常用函数使用--持续更新中

    NVL函数.NVL( string1, replace_with).如果string1为NULL,则NVL函数返回replace_with的值,否则返回原来的值. INSTR函数.用于查找指定字符串是 ...

随机推荐

  1. C#下在图片文件本地

    //C#下载图片文件到本地,c#,c#下载,下载图片,下载文件,下载函数// 从图片地址下载图片到本地磁盘// 将二进制文件保存到磁盘 using System;using System.Drawin ...

  2. TCP滑动窗口控制流量的原理

    TCP的滑动窗口机制       TCP这个协议是网络中使用的比较广泛,他是一个面向连接的可靠的传输协议.既然是一个可靠的传输协议就需要对数据进行确认.TCP协议里窗口机制有2种:一种是固定的窗口大小 ...

  3. java 获取URL链接 内容

    public static String getHtmlConentByUrl(String ssourl) {        try {             URL url = new URL( ...

  4. [转] 你真的会写单例模式吗——Java实现

    你真的会写单例模式吗——Java实现 原文:http://www.tuicool.com/articles/MBrUfy6 单例模式可能是代码最少的模式了,但是少不一定意味着简单,想要用好.用对单例模 ...

  5. winform控件跨线程委托

    1. this.listBox1.BeginInvoke(new Action(() => { if (listBox1.Items.Count > 20) listBox1.Items. ...

  6. GD库 图片缩略图 图片水印

    /** * GD库 图片缩略图 *//*$image = imagecreatefromjpeg("1.jpg");var_dump($image);exit;$width = i ...

  7. yii2.0 面包屑的使用

    yii2中面包屑是yii2自带的小部件,类似本网站的导航栏应该就是采用面包屑来完成的 例子如下,需要引入 yii\widgets\Breadcrumbs echo Breadcrumbs::widge ...

  8. namenode无法启动

    查看日志错误信息关键语句: There appears to be a gap in the edit log.  We expected txid 44353, but got txid 原因: n ...

  9. Linux命令学习-useradd和usermod

    1.useradd 创建用户的时候创建家目录 useradd luyun :创建用户luyun,系统会自动创建/home/luyun 目录,此目录便是luyun的家目录. useradd -d /ho ...

  10. C1FlexGrid小结(转自http://www.cnblogs.com/C1SupportTeam/archive/2012/12/11/2812316.html)

    C1FlexGrid控件来对一个表格格式中的数据进行显示,编辑,组和总结.该表格可以绑定到一个数据源,它可以对自己的数据进行管理. C1FlexGrid控件有一个包含以下元素的丰富的对象模型: 以下的 ...