【Oracle】Oracle常用函数

目录

  • 聚合函数
  • 数字函数
    • 1. ABS函数:返回一个数的绝对值。
    • 2. CEIL函数:返回大于等于给定数的最小整数。
    • 3. FLOOR函数:返回小于等于给定数的最大整数。
    • 4. ROUND函数:将一个数四舍五入到指定的小数位。
    • 5. MOD函数:返回两个数相除的余数。
    • 6. POWER函数:返回一个数的指定次幂。
    • 7. SQRT函数:返回一个数的平方根。
    • 8. EXP函数:返回一个数的指数值。
    • 9. LN函数:返回一个数的自然对数。
    • 10. LOG函数:返回一个数的对数,可以指定底数。
    • 11. TRUNC() 数值截断函数 (不四舍五入)
  • 日期函数
    • 获取系统当前时间
    • 日期加减函数
      • 1. 在日期上加上指定的月份。
      • 2. 在日期上加上指定的天数。
      • 3. 在日期上加上指定的小时数。
      • 4. 在日期上加上指定的分钟数。
      • 5. 在日期上加上指定的秒数。
    • 日期转换函数
      • 1. TO_DATE(date_string, format)
      • 2. TO_CHAR(date, format)
    • 日期间隔函数
    • 月份间隔函数
    • 日期截断函数
    • 返回指定日期当月的最后一天 LAST_DAY(日期)
    • 四舍五入式处理日期 ROUND
  • 字符串处理函数
    • 字符转换函数:TO_CHAR()
    • 字符拼接函数
    • 列转行函数 wm_concat(x)
      • 补充:行转列
    • 字符长度 LENGTH()
    • 字节长度 LENGTHB()
    • 位置查找函数 INSTR(x,str,m,n)
    • 替换函数REPLACE(字符串,旧的值,新的值)
    • 大小写转换
    • 截取函数 LTRIM(x,y)、RTRIM(x,y) 、TRIM(y,x)、SUBSTR(x,m,n)
    • 填充函数
      • 1. LPAD函数
      • 2. RPAD函数
      • 3. RTRIM函数
      • 4. LTRIM函数
      • 5. TRIM函数
  • 逻辑函数
    • 空值处理 nvl()、nvl2()
    • decode()函数
      • 可以与case when … 进行替换
  • 分析函数
    • 聚合函数+开窗函数
      • over() 里面不填内容
      • over(partition by 字段)分组
      • over( order by 字段) 排序
      • over(partition by 分组 order by 排序)
    • 分析函数配合 rows between and 使用
  • 排名函数
    • row_number()over()
    • rank()over()
    • dense_rank()over()
      • 有partition by 分组,就在组内进行排名
  • 偏移函数
    • lag()over() 向下偏移
    • lead()over() 向上偏移
      • 通过偏移计算 环比情况

聚合函数

  • 聚合函数:同时对多行进行操作,并返回一个结果 (别名 多行函数)。
  • 聚合函数 结合 GROUP BY 一起使用。
  • 使用 GROUP BY 以后 ,聚合函数会根据分组字段,每个组返回一个计算结果。
  • 聚合函数有:
    • 计算最大值:MAX()
    • 计算最小值:MIN()
    • 计算总和:SUM()
    • 计算平均值:AVG()
    • 计算总条数:COUNT()
select max(sal) from emp;  --查找员工表中工资的最大值 5000
select deptno,max(sal) from emp group by deptno;  --按照部门编号进行分组,找出每个部门中对应的员工工资的最大值。

select min(sal) from emp;  --查找员工表中工资的最小值 800
select deptno,min(sal) from emp group by deptno;  --按照部门编号进行分组,找出每个部门中对应的员工工资的最小值。

select sum(sal) from emp;  --求所有员工工资的总和 29025
select deptno,sum(sal) from emp group by deptno;  --按照部门编号进行分组,统计每个部门里面员工的工资总和。

select round(avg(sal),2) from emp;  --求所有员工工资的平均值 2073.21
select deptno,round(avg(sal),2) from emp group by deptno;  --按照部门编号进行分组,统计每个部门里面员工的工资的平均值。
# 注:round( x ,y )函数为四舍五入函数,指对数据 x 进行四舍五入,保留 y 位小数。

select count(empno) from emp;  --求员工表中的员工数 14
select deptno,count(empno) from emp group by deptno;  --按照部门编号进行分组,统计每个部门里面员工的人数。

数字函数

1. ABS函数:返回一个数的绝对值。

案例:

  SELECT ABS(-1) FROM DUAL; -- 1
  SELECT ABS(-1.544) FROM DUAL; -- 1.544
  SELECT ABS(0) FROM DUAL; -- 0

2. CEIL函数:返回大于等于给定数的最小整数。

案例:

  SELECT CEIL(4.23) FROM DUAL; -- 5
  SELECT CEIL(-4.23) FROM DUAL; -- -4
  SELECT CEIL(0) FROM DUAL; -- 0 

3. FLOOR函数:返回小于等于给定数的最大整数。

案例:

  SELECT FLOOR(4.23) FROM DUAL; -- 4
  SELECT FLOOR(-4.23) FROM DUAL; -- -5

4. ROUND函数:将一个数四舍五入到指定的小数位。

案例:

  ROUND(X,Y)  四舍五入函数 -- 会进行四舍五入
  SELECT ROUND(123.456,2) FROM DUAL;   -- 123.46

5. MOD函数:返回两个数相除的余数。

案例:

  SELECT MOD(8,2) FROM DUAL; -- 0
  SELECT MOD(8,3) FROM DUAL; -- 2
  SELECT MOD(8,3.2) FROM DUAL; -- 1.6

6. POWER函数:返回一个数的指定次幂。

案例:

  SELECT POWER(2,3) FROM DUAL;  --2的3次方 8
  SELECT POWER(2,3.4) FROM DUAL; -- 10.556
  SELECT POWER(-2,2) FROM DUAL;    --4 注:当x是负数时,y必须是整数,不能是小数;

7. SQRT函数:返回一个数的平方根。

案例:

SELECT SQRT(16) FROM dual;  -- 4

8. EXP函数:返回一个数的指数值。

案例:

SELECT EXP(2) FROM dual; -- 7.38905609893065

9. LN函数:返回一个数的自然对数。

案例:

SELECT LN(10) FROM dual;  -- 2.30258509299405

10. LOG函数:返回一个数的对数,可以指定底数。

案例:

SELECT LOG(100, 10) FROM dual;  - 2

11. TRUNC() 数值截断函数 (不四舍五入)

案例:

  TRUNC(X,Y)    --不会进行四舍五入
  SELECT TRUNC(123.456,2) FROM DUAL;  --在小数点之后第二位截断 123.45
  SELECT TRUNC(123.456,-1) FROM DUAL;  --在小数点之前第一位截断 120
  SELECT TRUNC(123.456,0) FROM DUAL;   -- 123

日期函数

获取系统当前时间

  select sysdate from dual;       --获取系统时间
  select current_date from dual;   --获取系统时间
  # 时间格式为:2024/7/5 8:49:32

日期加减函数

1. 在日期上加上指定的月份。

语法:ADD_MONTHS(date, num_months)

案例:

SELECT ADD_MONTHS(sysdate, 6) FROM dual; -- 当前日期加上6个月后的日期。
SELECT ADD_MONTHS(sysdate, -6) FROM dual; -- 当前日期减去6个月后的日期。

2. 在日期上加上指定的天数。

语法:date + num_days

案例:

SELECT sysdate + 7 FROM dual; -- 当前日期加上7天后的日期。
SELECT sysdate - 7 FROM dual; -- 当前日期减去7天后的日期。

3. 在日期上加上指定的小时数。

语法:date + (num_hours / 24)

案例:

SELECT sysdate + (3 / 24) FROM dual; -- 当前日期加上3小时后的日期。
SELECT sysdate - (3 / 24) FROM dual; -- 当前日期减去3小时后的日期。

4. 在日期上加上指定的分钟数。

语法:date + (num_minutes / (24 * 60))

案例:

SELECT sysdate + (30 / (24 * 60)) FROM dual; -- 当前日期加上30分钟后的日期。
SELECT sysdate - (30 / (24 * 60)) FROM dual; -- 当前日期减去30分钟后的日期。

5. 在日期上加上指定的秒数。

语法:date + (num_seconds / (24 * 60 * 60))

案例:

SELECT sysdate + (45 / (24 * 60 * 60)) FROM dual; -- 当前日期加上45秒后的日期。
SELECT sysdate - (45 / (24 * 60 * 60)) FROM dual; -- 当前日期减去45秒后的日期。

日期转换函数

1. TO_DATE(date_string, format)

  • 这个函数将一个日期字符串转换为一个日期值。
  • date_string 是要转换的日期字符串,而 format 则是日期字符串的格式。例如:
select TO_DATE('01-01-2022', 'DD-MM-YYYY') from dual; -- 返回日期值 2022-01-01。
select TO_DATE('2022-01-01', 'YYYY-MM-DD') from dual; -- 返回日期值 2022-01-01。

SELECT TO_CHAR(SYSDATE, 'YYYY-MM-DD HH24:MI:SS') AS formatted_date FROM dual; -- 返回当前日期和时间的格式化字符串,例如:'2021-12-21 14:30:45'。
  • 可以根据需要使用不同的日期格式化选项。以下是一些常用的日期格式化选项:
    • YYYY:四位数的年份
    • MM:两位数的月份(从01到12)
    • DD:两位数的日期(从01到31)
    • HH24:24小时制的小时(从00到23)
    • MI:两位数的分钟(从00到59)
    • SS:两位数的秒(从00到59)

2. TO_CHAR(date, format)

  • 这个函数将一个日期值转换为一个指定格式的字符串。
  • date 是要转换的日期值,而 format 则是要转换的日期字符串的格式。例如:
select TO_CHAR(SYSDATE, 'DD-MM-YYYY') from dual; -- 返回字符串 '21-12-2021'。

SELECT TO_CHAR(your_date_column, 'YYYY-MM-DD HH24:MI:SS') AS formatted_date FROM your_table; -- 将年月日时分秒转换为字符串,例如:'2021-12-21 14:30:45'

日期间隔函数

  select sysdate-to_date('20230101','YYYYMMDD') from dual; --间隔 241.36天
  select to_date('20230101','YYYYMMDD')-sysdate from dual;  -- -241.36
  -- 另一种形式
  select sysdate-date'2023-01-01' from dual;  --间隔241.36天
  • 注1:to_date(‘20230101’,‘YYYYMMDD’) 可以将字符串日期转变为指定格式日期输出,'YYYYMMDD’表示为 年/月/日 输出为2023/1/1 。
  • 注2:date’年-月-日’ :可表示一个日期

月份间隔函数

  select MONTHS_BETWEEN(sysdate,date'2023-01-01') from dual;  -- 7.94747834528076(单位 月)

  select MONTHS_BETWEEN(TO_DATE('31-12-2021', 'DD-MM-YYYY'), TO_DATE('01-01-2021', 'DD-MM-YYYY')) from dual; -- 返回值 12。

日期截断函数

  --- 返回这一年的 1月一号 2023/1/1
  SELECT TRUNC(SYSDATE,'YYYY') FROM DUAL;
  ---- 返回时间所在月的 一号 2023/8/1
  SELECT TRUNC(SYSDATE,'MM') FROM DUAL;
  --- 天,不带时分秒 2023/8/30 8:50:13  2023/8/30
  SELECT SYSDATE,TRUNC(SYSDATE,'DD') FROM DUAL;
  --- 当前所在星期的第一天 2023/8/30 8:50:13 2023/8/27(周日) 
  SELECT SYSDATE,TRUNC(SYSDATE,'D') FROM DUAL;
  --- 返回当前时间所在季度的第一天 2023/8/30 8:50:13 2023/7/1
  SELECT SYSDATE,TRUNC(SYSDATE,'Q') FROM DUAL;

返回指定日期当月的最后一天 LAST_DAY(日期)

  SELECT LAST_DAY(SYSDATE) FROM DUAL; -- 2023/8/31 8:57:36
--TRUNC 函数返回的结果作为 LAST_DAY 函数的参数 ,函数嵌套
  SELECT LAST_DAY(TRUNC(SYSDATE,'DD'))FROM DUAL; -- 2023/8/31

四舍五入式处理日期 ROUND

  ---如果为“YEAR”则舍入到某年的1月1日,即前半年舍去,后半年作为下一年
  SELECT ROUND(SYSDATE,'YEAR') FROM DUAL;  --下半年 2024/1/1
  SELECT ROUND(date'2023-05-23','YEAR') FROM DUAL;  --上半年 2023/1/1
---如果为“MONTH”则舍入到某月的1日,即前半月舍去,后半月作为下一月。
  SELECT ROUND(SYSDATE,'MONTH') FROM DUAL; --2023/9/1
  SELECT ROUND(SYSDATE-15,'MONTH') FROM DUAL; --2023/8/1
---默认为“DDD”,即月中的某一天,最靠近的天,前半天舍去,后半天作为第二天
  SELECT ROUND(to_date('20230411092334','YYYYMMDD HH12MISS'),'DDD') FROM DUAL; --2023/4/11
  SELECT ROUND(SYSDATE,'DDD') FROM DUAL; --2023/8/30
----如果为“DAY”则舍入到最近的周的周日,即上半周舍去,下半周作为下一周周日
  SELECT ROUND(SYSDATE,'DAY') FROM DUAL; --2023/8/27
  SELECT ROUND(SYSDATE+3,'DAY') FROM DUAL; --2023/9/3
  SELECT ROUND(to_date('20230809120000','YYYYMMDD HH12MISS'),'DAY') FROM DUAL; --2023/8/13

字符串处理函数

字符转换函数:TO_CHAR()

    select to_char(to_date('20230819','YYYYMMDD'),'Q') from dual; --返回当前时间所在季度 3
    select to_char(sysdate,'day') from dual;  --返回当前日期所在的星期 星期三 
    SELECT TO_CHAR(SYSDATE,'YYYY') FROM DUAL;  --返回当前所在年份 2023
    SELECT TO_CHAR(SYSDATE,'MM') FROM DUAL; --返回当前所在月份 08
    SELECT TO_CHAR(SYSDATE,'DD') FROM DUAL; --返回当前所在月的日 30
    SELECT TO_CHAR(SYSDATE,'YYYYMMDD') FROM DUAL; --返回当前所在日期的年月日 20230830

字符拼接函数

    select concat(concat(e.ename,e.empno),'hahaha') from emp e; --例 SMITH7369hahaha
    select concat('HELLO','ORACLE') from dual; --HELLOORACLE
	## 推荐这种写法
	select 'hello' || ' world !' from dual; -- hello world !

列转行函数 wm_concat(x)

wm_concat(x) 跟group by 一起使用,将每一组的多行的某个字段的数据拼接到一行,并逗号隔开

    select e.deptno,wm_concat(e.ename) from emp e group by e.deptno; -- 按照部门进行分组,将同组的员工姓名拼接到同一行。

	--加distinct 去重
    select e.deptno,wm_concat(distinct e.job) 拼接 from emp e group by e.deptno; --  按照部门编号分组,将同部门的工作岗位进行拼接。

补充:行转列

Oracle数据库中并没有内置的行转列函数,但可以使用pivot操作实现行转列的功能。pivot操作允许您将行数据转化为列数据,并将列的值从行数据中聚合。

以下是使用pivot操作实现行转列的示例:

假设有一个名为"sales"的表,记录了每个销售人员在不同月份的销售额:

salesperson   month   sales_amount
----------------------------------
John          Jan     1000
John          Feb     1500
John          Mar     800
Alice         Jan     1200
Alice         Feb     1800
Alice         Mar     900

现在我们希望将每个销售人员的销售额按月份转化为列数据。可以使用pivot操作实现:

SELECT *
FROM
(
    SELECT salesperson, month, sales_amount
    FROM sales
)
PIVOT
(
    SUM(sales_amount)
    FOR month IN ('Jan', 'Feb', 'Mar')
)
ORDER BY salesperson;

执行上述查询后,将得到以下结果:

salesperson   Jan   Feb   Mar
-----------------------------
Alice         1200  1800  900
John          1000  1500  800

这样就将原表中的每个月份的销售额转化为了列数据,方便了数据的分析和查看。

字符长度 LENGTH()

    select length('ABCF') from dual; -- 4
    select length('中国') from dual; -- 2

字节长度 LENGTHB()

    select lengthb('ABCF') from dual; --4 一个英文占一个字节
    select lengthb('中国') from dual; --4 一个汉字占两个字节

位置查找函数 INSTR(x,str,m,n)

x表示原字符串,str目标字符,m从哪个位置开始找(默认为 1 ,正数从左往右找),n表示第几次出现(默认为1)。返回值为找到的目标位置,没有找到返回为 0

    select instr('hello word','o',1,1) from dual; -- 5
    select instr('hello word','o',6,2) from dual; -- 0
    select instr('helloword','o',-1,1) from dual; -- 7
    select instr('helloword','or') from dual; -- 7

替换函数REPLACE(字符串,旧的值,新的值)

    select replace('helloword','or','MM') from dual; --or 替换成 MM ,得到 hellowMMd
    select replace('helloword','o','S') from dual; --o 替换成 S ,得到 hellSwSrd
    select replace('helloword','ord','D') from dual; --连续字符才可以替换 ord 替换成 D, 得到 hellowD
    select replace(ename,'S','MM'),ename from emp;

大小写转换

    select upper('helloword') from dual; -- HELLOWORD
    select lower('HELLO ORACLE') from dual; -- hello oracle

截取函数 LTRIM(x,y)、RTRIM(x,y) 、TRIM(y,x)、SUBSTR(x,m,n)

  • 截去函数截去掉包含在后面的参数 y 中的任意一个或多个字符,要求包含在参数 y 内,并且是连续的。
    • LTRIM(x,y) 从左边开始,截去 x 中包含在参数 y 中的字符,默认截去空格
    • RTRIM(x,y) 从右边开始,截去 x 中包含在参数 y 中的字符,默认截去空格
    • TRIM(y from x) 两边截去 x 中包含的参数 y 中的字符,缺省时去空格 --截去只能填一个字符 y
   select ltrim('SASCDFVGS','S') from dual; --ASCDFVGS
   select rtrim('SASCDFVGS','S') from dual; --SASCDFVG
   select trim('    SASCDFVGS    ') from dual; --SASCDFVGS 去除两边空格
   select trim('S' from 'SASCDFVGS') from dual; --ASCDFVG
  • SUBSTR(x,m,n)
    • 从原字符串 x 中的第 m 位开始截取,截取 n 个长度。
    select substr('DDSIYYDSILOVEU',9,6) from dual; --从第九个位置开始截取,截取六个长度 ILOVEU
    select substr('DDSIYYDSILOVEU',-6,6) from dual; --从第九个位置开始截取,截取六个长度 ILOVEU
    select substr('DDSIYYDSILOVEU',-6) from dual; --从右往左第六个位置开始截取,默认截取到最后位 ILOVEU

填充函数

1. LPAD函数

  • 该函数将指定的字符串用指定的字符填充到指定的长度。语法: LPAD(string, length, pad_char)
SELECT LPAD('Hello', 10, '*') FROM dual; -- *****Hello

2. RPAD函数

  • 该函数与LPAD函数类似,只是将填充字符放在字符串的末尾。语法:RPAD(string, length, pad_char)
SELECT RPAD('Hello', 10, '*') FROM dual; -- Hello*****

3. RTRIM函数

  • 该函数用于移除字符串末尾指定的字符。语法: RTRIM(string, [trim_char])
SELECT RTRIM('Hello***', '*') FROM dual; -- Hello

4. LTRIM函数

  • 该函数用于移除字符串开头指定的字符。语法:LTRIM(string, [trim_char])
SELECT LTRIM('***Hello', '*') FROM dual; -- Hello

5. TRIM函数

  • 该函数用于移除字符串两端指定的字符。语法:TRIM(trim_char FROM string)
SELECT TRIM('*' FROM '*Hello*') FROM dual; -- Hello

逻辑函数

空值处理 nvl()、nvl2()

  • nvl(列名,默认值):对空值进行默认值处理
  • nvl2(列名,不为空的处理,空值的处理):对含空值的字段的数据,进行空值和非空值这两个情况进行处理
  select job,nvl(comm,0) from emp;  --将奖金为空值的数据赋予默认值 0        
  select job,nvl2(comm,sal+comm,0) from emp;  --若奖金为空,则赋予默认值0,否则返回为工资+奖金

decode()函数

decode(列名,判断值1,结果值1,判断值2,结果值2,):可以对某个字段多种情况进行精准判断

  select ename,job,decode(job,'MANAGER',sal*1.3,'SALESMAN',sal*1.2,sal*1.1) from emp; --根据不同的工作岗位进行 涨薪
  select ename,decode(comm,null,0,sal+comm) from emp; --若奖金为空,则赋予默认值0,否则返回为工资+奖金

可以与case when … 进行替换

case … when … 数据判断的逻辑语句

# 语法
case
    when 条件判断1 then 执行结果1
    when 条件判断2 then 执行结果2
    ...
    else 执行结果
  end --可用 as 取个别名

# 案例
--查询每个人得到工资等级,2000以下是C,2000-3000是B,3000以上是A 
select ename,job,
  case 
     when sal<2000 then 'C'
     when sal between 2000 and 3000 then 'B'
     else 'A'
  end as 工资等级
  from emp;

分析函数

分析函数 = 聚合函数+开窗函数over()

  • 开窗函数:over()
  • 分析函数语法:聚合函数()或者单行函数() + over( partition by 分组 order by 排序)
  • 分析函数的运用:对表格的数据进行统一的或者是分组的计算,将计算的结果当成一个新的列,直接拼接在表格的后面。

聚合函数+开窗函数

sum()over(),max()over(),min()over(),count()over,avg()over 对整个表格的数据进行计算。

over() 里面不填内容

select e.*,sum(sal)over() from emp e;
select e.*,max(sal)over() from emp e;
select e.*,min(sal)over() from emp e;
select e.*,count(sal)over() from emp e;
select e.*,avg(sal)over() from emp e;

聚合函数得到的结果,生成新的一列数据字段,在查询结果中展示。
在这里插入图片描述

over(partition by 字段)分组

对某个分组内的数据进行统计和计算

--将每个部门的工资总和 拼接在 对应部门  每条数据 后面
select emp.*, sum(sal) over(partition by deptno) 
from emp;

在这里插入图片描述

over( order by 字段) 排序

在整个表格的范围内,对数据进行 ’累计‘ 的统计。

select e.*,sum(sal)over(order by e.empno asc) from emp e; --按员工编号进行升序排序,并累计统计员工工资 如下图所示
select e.*,max(sal)over(order by e.empno asc) from emp e; --按员工编号进行升序排序,并按排序结果一步一步找对对应的最大工资
select e.*,min(sal)over(order by empno asc) from emp e; --按员工编号进行升序排序,并按排序结果一步一步找对对应的最小工资
select e.*,count(1)over(order by e.empno asc) from emp e; --按员工编号进行升序排序,并按排序结果累计统计当前员工人数
select e.*,count(sal)over(order by e.empno asc) from emp e; --按员工编号进行升序排序,并按排序结果累计统计当前员工人数
select e.*,avg(sal)over(order by e.empno asc) from emp e; --按员工编号进行升序排序,并按排序结果计算当前排序情况的平均工资

在这里插入图片描述

over(partition by 分组 order by 排序)

在整个表格的范围内,对数据进行某个字段排序的 ’累计‘ 的统计。

select emp.*, 
sum(sal)over(partition by deptno order by empno asc)
from emp;

按照部门编号进行了分组,并按照员工编号进行了升序排序。最后逐步统计部门的员工工资的总和。
在这里插入图片描述

分析函数配合 rows between and 使用

  • CURRENT ROW:当前行
  • n PRECEDING:往前n行
  • n FOLLOWING:往后n行
  • UNBOUNDED PRECEDING:表示从前面的起点
  • UNBOUNDED FOLLOWING:表示到后面的终点
SELECT DEPTNO,ENAME,HIREDATE,SAL,
      SUM(SAL) OVER()      AS S1, --所有行相加
      SUM(SAL) OVER(PARTITION BY DEPTNO)      AS S2, --按DEPTNO分组,组内数据相加
      SUM(SAL) OVER(PARTITION BY DEPTNO ORDER BY HIREDATE) AS S3, --按DEPTNO分组,组内数据累加
      SUM(SAL) OVER(PARTITION BY DEPTNO ORDER BY HIREDATE 
      ROWS BETWEEN UNBOUNDED PRECEDING AND CURRENT ROW) AS  S4, --和S3效果相同,
      --由起点到当前行聚合
      SUM(SAL) OVER(PARTITION BY DEPTNO ORDER BY HIREDATE
       ROWS BETWEEN 1 PRECEDING AND CURRENT ROW)         AS S5, --当前行和前面1行聚合
      SUM(SAL) OVER(PARTITION BY DEPTNO ORDER BY HIREDATE 
      ROWS BETWEEN 1 PRECEDING AND 1 FOLLOWING)          AS S6,  --前1行,当前行及后1行聚合
      SUM(SAL) OVER(PARTITION BY DEPTNO ORDER BY HIREDATE 
      ROWS BETWEEN CURRENT ROW AND UNBOUNDED FOLLOWING) AS S7 --当前行到最后一行聚合
      FROM EMP;

在这里插入图片描述

排名函数

  • 排名函数 是一定要排序才能有排名的函数。
  • 语法:单行函数() + over(partition by 分组 order by 排序)

row_number()over()

按照顺序,给每一行定义一个有顺序的排序数字,依次排序。没有并列排名情况 1 2 3 4 5

  select emp.*,
  row_number() over(order by sal desc) r  --按工资降序排序。 
  from emp;

在这里插入图片描述

rank()over()

按照顺序,如果有相同的值,那么会产生并列的排名,而且会跳过占用的名次 1 2 3 3 5

  select emp.*,                                           
  rank() over(order by sal desc) r
  from emp;

在这里插入图片描述

dense_rank()over()

按照顺序,如果有相同的值,那么会产生并列的排名,但是不会跳过占用的名次 1 2 3 3 4

 select emp.*,                                                             
 dense_rank() over(order by sal desc) r
 from emp;

在这里插入图片描述

有partition by 分组,就在组内进行排名

 select emp.*,                                                            
 row_number() over(partition by deptno order by sal desc) r
 from emp;

在这里插入图片描述

偏移函数

  • LAG和LEAD函数可以在一次查询中取出同一字段的前N行的数据和后N行的值。
  • 语法:LAG(ARG1,ARG2,ARG3)over(partition by 字段 order by 字段)
  • 参数解释:
    • LAG 往下面多少行找
    • 第一个参数是偏移哪个字段的数据
    • 第二个参数是偏移多少行
    • 第三个参数是当偏移之后找不到数据,就给的一个默认值
    • ORDER BY 必须要有
    • PARTITION BY 可以省略,当省略的时候就是整张表的数据做偏移,不分组
    • 当 PARTITION BY 存在时,就是在每一组里边进行偏移

lag()over() 向下偏移

SELECT T.*,LAG(T.SAL,2,0)OVER(PARTITION BY T.DEPTNO ORDER BY T.SAL DESC) LAG_SAL
FROM EMP T;

员工按部门进行分组,并按降序进行排序,之后将工资向下偏移 2 个位置,生成新列,没有数据则补充为 0 。
在这里插入图片描述

lead()over() 向上偏移

SELECT T.*,LEAD(T.SAL,2,0)OVER(PARTITION BY T.DEPTNO ORDER BY T.SAL DESC) LEAD_SAL
FROM EMP T;

员工按部门进行分组,并按降序进行排序,之后将工资向上偏移 2 个位置,生成新列,没有数据则补充为 0 。
在这里插入图片描述

通过偏移计算 环比情况

  • 环比:环比的定义和计算方法:环比是指当前时间段的数据与上一个时间段的数据相比较的增长率,通常用百分数表示。环比计算方法如下:环比增长率 = (当前时间段数据 - 上一个时间段数据) / 上一个时间段数据 × 100%
  • 数据声明:
    在这里插入图片描述
  --用lag()over()
  select t.ym,t.amt-lag(t.amt,1)over(order by t.ym) 环比情况
  FROM SAL t

  --用lead()over()
  select t.ym,t.amt-lead(t.amt,1)over(order by t.ym desc) 环比情况
  FROM SAL t
  order by t.ym;

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:/a/778129.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

Ubuntu固定虚拟机的ip地址

1、由于虚拟机网络是桥接&#xff0c;所以ip地址会不停地变化&#xff0c;接下来我们就讲述ip如何固定 2、如果apt安装时报错W: Target CNF (multiverse/cnf/Commands-all) is configured multiple times in /etc/apt/sources.list:10&#xff0c; 检查 /etc/apt/sources.list…

SpringBoot新手快速入门系列教程二:MySql5.7.44的免安装版本下载和配置,以及简单的Mysql生存指令指南。

我们要如何选择MySql 目前主流的Mysql有5.0、8.0、9.0 主要区别 MySQL 5.0 发布年份&#xff1a;2005年特性&#xff1a; 基础事务支持存储过程、触发器、视图基础存储引擎&#xff08;如MyISAM、InnoDB&#xff09;外键支持基本的全文搜索性能和扩展性&#xff1a; 相对较…

HTML+CSS+JavaScript入门学习

目录 1. 前言2. HTML2.1 HTML简介2.2 HTML标签 3. CSS3.1 CSS知识整理及总结3.2 CSS之flex布局 4. JavaScript4.1 JavaScript知识整理及总结1-基础篇4.2 JavaScript知识整理及总结2-进阶篇 1. 前言 本文主要采用转载的形式&#xff0c;偶尔发现了一个比较不错的博客站点&#…

华为ENSP防火墙+路由器+交换机的常规配置

(防火墙区域DHCP基于接口DHCP中继服务器区域有线区域无线区域&#xff09;配置 一、适用场景&#xff1a; 1、普通企业级网络无冗余网络环境&#xff0c;防火墙作为边界安全设备&#xff0c;分trust&#xff08;内部网络信任区域&#xff09;、untrust&#xff08;外部网络非信…

计算机网络-IP组播基础

一、概述 在前面的学习交换机和路由协议&#xff0c;二层通信是数据链路层间通信&#xff0c;在同一个广播域间通过源MAC地址和目的MAC地址进行通信&#xff0c;当两台主机第一次通信由于不清楚目的MAC地址需要进行广播泛洪&#xff0c;目的主机回复自身MAC地址&#xff0c;然后…

JSP WEB开发(一) JSP语言基础

目录 JSP JSP简介&#xff1a; JSP页面 JSP运行原理 JSP脚本元素 JAVA程序片 局部变量 全局变量和方法的声明 全局变量 方法的声明 程序片执行特点 synchronized关键字 表达式 JSP指令标记 page指令 include指令 JSP动作标记 JSP动作元素include和include指令的…

【C++】B树及其实现

写目录 一、B树的基本概念1.引入2.B树的概念 二、B树的实现1.B树的定义2.B树的查找3.B树的插入操作4.B树的删除5.B树的遍历6.B树的高度7.整体代码 三、B树和B*树1.B树2.B*树3.总结 一、B树的基本概念 1.引入 我们已经学习过二叉排序树、AVL树和红黑树三种树形查找结构&#x…

1-3 NLP为什么这么难做

1-3 NLP为什么这么难做 主目录点这里 字词结构的复杂性 中文以汉字为基础单位&#xff0c;一个词通常由一个或多个汉字组成&#xff0c;而不像英语词汇单元由字母构成。这使得中文分词&#xff08;切分句子为词语&#xff09;成为一个具有挑战性的任务。语言歧义性 中文中常…

Mysql-常见DML-DQL-语句语法用法总结

1、常见DML语句 1.1 INSERT语句 说明&#xff1a;将数据插入到数据库表中。 INSERT INTO table_name (column1, column2, ...) VALUES (value1, value2, ...); 实例&#xff1a;添加C罗信息到数据库表中 insert into employee (ID, name, gender, entrydate, age) values …

eclipse断点调试(用图说话)

eclipse断点调试&#xff08;用图说话&#xff09; debug方式启动项目&#xff0c;后端调试bug调试 前端代码调试&#xff0c;请参考浏览器断点调试&#xff08;用图说话&#xff09; 1、前端 选中一条数据&#xff0c;点击删除按钮 2、后端接口打断点 断点按钮 介绍 resu…

python如何设计窗口

PyQt是一个基于Qt的接口包&#xff0c;可以直接拖拽控件设计UI界面&#xff0c;下面我简单介绍一下这个包的安装和使用&#xff0c;感兴趣的朋友可以自己尝试一下&#xff1a; 1、首先&#xff0c;安装PyQt模块&#xff0c;这个直接在cmd窗口输入命令“pip install pyqt5”就行…

Hugging Face 全球政策负责人首次参加WAIC 2024 前沿 AI 安全和治理论坛

Hugging Face 全球政策负责人艾琳-索莱曼 &#xff08; Irene Solaiman &#xff09;将参加7月5日在上海举办的WAIC-前沿人工智能安全和治理论坛&#xff0c;并在现场进行主旨演讲和参加圆桌讨论。具体时间信息如下&#xff1a;主旨演讲&#xff1a;开源治理的国际影响时间 &am…

YOLOv8改进 添加轻量级注意力机制ELAttention

一、ELA论文 论文地址:2403.01123 (arxiv.org) 二、Efficient Local Attention结构 ELA (Efficient Local Attention) 被用于处理自然语言处理任务中的序列数据。它旨在提高传统注意力机制的效率,并减少其计算和存储成本。 在传统的注意力机制中,计算每个输入位置与所有其…

fastadmin 如何给页面添加水印

偶然发现fastadmin框架有个水印插件&#xff0c;看起来漂亮&#xff0c;就想也实现这样的功能&#xff0c;看到需要费用。但是现成的插件需要费用&#xff0c;自己动手丰衣足食。说干就干。 1. 找到watermark.js &#xff0c;放到assets/js/ 下面 2.具体页面引入 <script…

【深度学习】图形模型基础(5):线性回归模型第四部分:预测与贝叶斯推断

1.引言 贝叶斯推断超越了传统估计方法&#xff0c;它包含三个关键步骤&#xff1a;结合数据和模型形成后验分布&#xff0c;通过模拟传播不确定性&#xff0c;以及利用先验分布整合额外信息。本文将通过实际案例阐释这些步骤&#xff0c;展示它们在预测和推断中的挑战和应用。…

Docker 运行Nacos无法访问地址解决方法

参考我的上一篇文章去配置好镜像加速器&#xff0c;镜像加速器不是配置越多越好&#xff0c;重试次数多了会失败 Dockerhub无法拉取镜像配置阿里镜像加速器-CSDN博客 错误的尝试 最开始按照网上的方式去配了一大堆&#xff0c;发现下不下来。 镜像源地址&#xff1a;https:…

奇景光电战略投资Obsidian,共筑热成像技术新未来

5月29日,业界领先的IC设计公司奇景光电宣布,将对热成像传感器解决方案制造商Obsidian进行战略性投资,并以主要投资者的身份,参与到Obsidian的可转换票据融资活动中。虽然奇景光电并未公开具体的投资金额,但这一举动无疑向市场传递了一个明确的信号:奇景光电对Obsidian的技…

web Worker学习笔记 | 浏览器切换标签,定时器失效的解决办法

文章目录 web Workerweb Worker介绍 - 多线程解决方案浏览器多进程架构 web workers 的使用关闭worker引用其他js文件 浏览器切换标签&#xff0c;定时器失效的解决办法窗口可见性 API解决定时器失效的方案 web Worker web Worker介绍 - 多线程解决方案 Web Workers 是Html5提…

项目收获总结--MySQL的知识收获

一、概述 最近几天公司项目开发上线完成&#xff0c;做个收获总结吧~ 今天先记录MySQL的收获和提升。 二、MySQL表分区 项目中遇到数据量过大导致在查询过程中会出现各种超时的情况&#xff0c;当然是可以使用各种中间件比如MyCat&#xff0c;ShardingJDBC 等分库工具来进行…

项目实战--Spring Boot + Minio文件切片上传下载

1.搭建环境 引入项目依赖 <!-- 操作minio的java客户端--> <dependency><groupId>io.minio</groupId><artifactId>minio</artifactId><version>8.5.2</version> </dependency> <!-- jwt鉴权相应依赖--> &…