返回顶部
首页 > 资讯 > 精选 >Oracle数据库函数怎么用
  • 795
分享到

Oracle数据库函数怎么用

2023-06-22 05:06:31 795人浏览 八月长安
摘要

小编给大家分享一下oracle数据库函数怎么用,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!1、什么是窗口函数?窗口函数也属于分析函数。Oracle从8.1.6开

小编给大家分享一下oracle数据库函数怎么用,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!

1、什么是窗口函数?

窗口函数也属于分析函数。Oracle从8.1.6开始提供窗口函数,窗口函数用于计算基于组的某种聚合值,
窗口函数指定了分析函数工作的数据窗口大小,这个数据窗口大小可能会随着行的变化而变化。
与聚合函数的不同之处是:对于每个组返回多行,而聚合函数对于每个组只返回一行

基本语法: ‹分析函数› over (partition by ‹用于分组的列名› order by ‹用于排序的列名›)。语法中的‹分析函数›主要由序列函数(rank、dense_rank和row_number等组成)与聚合函数(sum、avg、count、max和min等)作为窗口函数组成。

从窗口函数组成上看,它是group by 和 order by的功能组合,group by分组汇总后改变了表的行数,一行只有一个类别,而partiition by则不会减少原表中的行数。
恰如窗口函数的组成,它同时具有分组和排序的功能,且不减少原表的行数。
OVER 关键字表示把函数当成窗口函数而不是聚合函数。sql 标准允许将所有聚合函数用做窗口函数,使用 OVER 关键字来区分这两种用法。

2、窗口函数——开窗

OVER 关键字后的括号中经常添加选项用以改变进行聚合运算的窗口范围。如果 OVER 关键字后的括号中的选项为空,则窗口函数会对结果集中的所有行进行聚合运算。

分析函数 over(partition by 列名 order by 列名 rows between 开始位置 and 结束位置)

为什么叫开窗呢?

因为在over()括号中的,partition() 函数可以将查询到的数据进行单独开一个窗口处理。譬如,查询每个班级的学生的排名情况,查询每个国家的历年人口等,诸如此类,都是在查询到的每一个班级、每一个国家中都开一个窗口,单独去执行命令。

rows和range分别表示选择后几行、选择数据范围
理解 rows between 含义,也叫做window子句:

preceding:往前following:往后current row:当前行unbounded:无边界,unbounded precending 表示从最前面的起点开始, unbounded following:表示到最后面的终点注:不加 partition by 的话则把整个数据集当作一个分区,不加 order by的话会对某些函数统计结果产生影响,如sum()

3、一些分析函数的使用方法

聚合函数

聚合函数定义
sum()求和
max()求最大值
min()求最小值
avg()求平均值
count()统计数

序列函数

序列函数定义
row_number()按照值排序时产生一个自增编号,值相等时不会重复,不会产生空位
rank()按照值排序时产生一个自增编号,值相等时会重复,会产生空位
dense_rank()按照值排序时产生一个自增编号,值相等时会重复,不会产生空位

row_number()

select * ,row_number()over(oder by 成绩 desc) as 排名 from 班级表

查询结果:

+------------+--------+------+------+------+| 姓名       | 性别   | 班级  | 成绩 | 排名 |+------------+--------+------+------+------+| 张三       | 男      | 1    | 100  | 1    || 李四       | 女      | 3    | 100  | 2    || 张三       | 女      | 1    | 100  | 3    || 王五       | 女      | 2    | 99   | 4    || 赵四       | 男      | 2    | 90   | 5    || 孙六       | 男      | 2    | 90   | 6    || 喜羊羊     | 男      | 3    | 85   | 7    || 美羊羊     | 女      | 4    | 82   | 8    || 懒洋洋     | 女      | 1    | 80   | 9    || 慢羊羊     | 女      | 2    | 70   | 10   |+------------+--------+------+------+------+

rank()

select * ,rank()over(oder by 成绩 desc) as 排名 from 班级表

查询结果:

+------------+--------+------+------+------+| 姓名       | 性别   | 班级  | 成绩 | 排名 |+------------+--------+------+------+------+| 张三       | 男      | 1    | 100  | 1    || 李四       | 女      | 3    | 100  | 1    || 张三       | 女      | 1    | 100  | 1    || 王五       | 女      | 2    | 99   | 4    || 赵四       | 男      | 2    | 90   | 5    || 孙六       | 男      | 2    | 90   | 5    || 喜羊羊     | 男      | 3    | 85   | 7    || 美羊羊     | 女      | 4    | 82   | 8    || 懒洋洋     | 女      | 1    | 80   | 9    || 慢羊羊     | 女      | 2    | 70   | 10   |+------------+--------+------+------+------+

dense_rank()

select * ,row_number()over(oder by 成绩 desc) as 排名 from 班级表

查询结果:

+------------+--------+------+------+------+| 姓名       | 性别   | 班级  | 成绩 | 排名 |+------------+--------+------+------+------+| 张三       | 男      | 1    | 100  | 1   || 李四       | 女      | 3    | 100  | 1   || 张三       | 女      | 1    | 100  | 1   || 王五       | 女      | 2    | 99   | 2   || 赵四       | 男      | 2    | 90   | 3   || 孙六       | 男      | 2    | 90   | 3   || 喜羊羊     | 男      | 3    | 85   | 4   || 美羊羊     | 女      | 4    | 82   | 5   || 懒洋洋     | 女      | 1    | 80   | 6   || 慢羊羊     | 女      | 2    | 70   | 7   |+------------+--------+------+------+------+

其他类

其他类定义
percent_rank()分组内当前行的rank值-1/分组内总行数-1
lag()用于统计窗口内往上第n行值 第一个参数为列名,第二个参数为往上第n行(可选,默认为1),第三个参数为默认值(当往上第n行为NULL时候,取默认值,如不指定,则为NULL
lead()用于统计窗口内往下第n行值 第一个参数为列名,第二个参数为往下第n行(可选,默认为1),第三个参数为默认值(当往下第n行为NULL时候,取默认值,如不指定,则为NULL
ntile()用于将分组数据按照顺序切分成n片,返回当前切片值
first_value()取分组内排序后,截止到当前行,第一个值
last_value()取分组内排序后,截止到当前行,最后一个值
cume_dist()返回小于等于当前值的行数/分组内总行数

4、OVER()参数——分组函数

partition by 子句:

窗口函数的 over 关键字后括号中的可以使用 partition by 子句来定义行的分区来供进行聚合计算。与 group by 子句不同,partition by 子句创建的分区是独立于结果集的,创建的分区只是供进行聚合计算的,而且不同的窗口函数所创建的分区也不互相影响。

5、OVER()参数——排序函数

order by 子句:

窗口函数中可以在over关键字后的选项中使用order by 子句来指定排序规则,而且有的窗口函数还要求必须指定排序规则。使用order by 子句可以对结果集按照指定的排序规则进行排序,并且在一个指定的范围内进行聚合运算。语法:ORDER BY字段名  RANGE|ROWS  BETWEEN边界规则1  AND  边界规则2

PARTITION BY子句和ORDER BY 可以共同使用,从而可以实现更加复杂的功能

以上是“Oracle数据库函数怎么用”这篇文章的所有内容,感谢各位的阅读!相信大家都有了一定的了解,希望分享的内容对大家有所帮助,如果还想学习更多知识,欢迎关注编程网精选频道!

--结束END--

本文标题: Oracle数据库函数怎么用

本文链接: https://lsjlt.com/news/302663.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

猜你喜欢
  • Oracle数据库函数怎么用
    小编给大家分享一下Oracle数据库函数怎么用,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!1、什么是窗口函数?窗口函数也属于分析函数。Oracle从8.1.6开...
    99+
    2023-06-22
  • Oracle数据库中to_date()函数怎么使用
    在Oracle数据库中,to_date()函数用于将一个字符串转换为日期格式。 to_date()函数的语法如下: to_date(...
    99+
    2023-10-23
    Oracle数据库
  • 常用oracle数据库函数总结
    wm_concat的基本语法    select proj_id,max(scale_valus) as scale_valus  &n...
    99+
    2024-04-02
  • Oracle数据库分析函数用法
    目录1、什么是窗口函数?2、窗口函数——开窗3、一些分析函数的使用方法4、OVER()参数——分组函数5、OVER()参数——排序函数1、什么是窗口函数? 窗口函数也属于分析函数。O...
    99+
    2024-04-02
  • ORACLE数据库 开窗函数
    开窗函数 2.1开窗函数的定义及语法 开窗函数(又名:分析函数,窗口函数,OLAP函数) 聚合函数:将数据按照一定的规则分组,统一分析各组的某项情况,每个分组返回一行结果 开窗函数:将数据按照一定的规则分组,统一分析各组的某项情况,每行数据...
    99+
    2023-09-02
    数据库 oracle python
  • MySQL8数据库中函数怎么用
    小编给大家分享一下MySQL8数据库中函数怎么用,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!数据库中内置函数的使用该篇主要介绍...
    99+
    2024-04-02
  • 数据库getdate函数怎么使用
    在 SQL Server 数据库中,GETDATE() 函数用于返回当前系统的日期和时间。使用方法很简单,只需要在查询中使用该函数即...
    99+
    2024-03-12
    数据库
  • Oracle数据库中通用的函数是什么
    这篇文章主要为大家展示了“Oracle数据库中通用的函数是什么”,内容简而易懂,条理清晰,希望能够帮助大家解决疑惑,下面让小编带领大家一起研究并学习一下“Oracle数据库中通用的函数是什么”这篇文章吧。一、 Scott用户下的表结构SCO...
    99+
    2023-06-29
  • oracle数据库怎么使用
    使用 oracle 数据库的步骤包括:1. 安装 oracle 数据库; 2. 创建数据库; 3. 连接到数据库; 4. 创建表; 5. 插入数据; 6. 查询数据; 7. 更新数据; ...
    99+
    2024-04-02
  • oracle数据库怎么用dbms
    使用 oracle dbms 的步骤如下:连接到数据库。创建数据库。创建表。插入数据。查询数据。更新数据。删除数据。管理用户和权限。备份和恢复数据库。 如何使用 Oracle 数据库的...
    99+
    2024-05-21
    oracle 数据丢失
  • oracle数据库怎么查询数据
    oracle 数据库中使用 sql 查询数据的方法:使用 "sqlplus" 命令连接到数据库;执行 "select" 语句,指定要提取的列和表;可选:使用 "order by...
    99+
    2024-04-08
    oracle 排列
  • oracle数据库怎么备份数据
    oracle数据库提供多种备份数据的方法:rman备份:使用recovery manager (rman)进行完整备份和恢复;exp/imp导出和导入:导出和导入数据,适用于小到中型数据...
    99+
    2024-04-08
    oracle
  • oracle数据库怎么导入数据
    在Oracle数据库中,可以使用SQL*Loader工具来导入数据。以下是一些基本步骤: 创建一个控制文件,用于指定要导入的数据文...
    99+
    2024-04-09
    oracle
  • oracle怎么删除数据库数据
    要删除Oracle数据库中的数据,您可以使用DELETE语句。以下是一个简单的例子: DELETE FROM table_n...
    99+
    2024-04-09
    Oracle 数据库
  • oracle数据库怎么建库
    在Oracle数据库中,可以使用`CREATE DATABASE`语句来创建数据库。首先,确保你有适当的权限来创建数据库。然后,打开...
    99+
    2023-08-29
    Oracle
  • oracle数据库groupby怎么使用
    在Oracle数据库中,使用GROUP BY子句可以将查询结果按照指定的列进行分组。具体用法如下: SELECT colum...
    99+
    2024-04-09
    oracle
  • oracle怎么看数据库用户
    在 oracle 中查看数据库用户,可以按照以下步骤进行:使用 sql*plus 客户端登录 sysdba 用户。查询用户列表以获取所有用户用户名。查询特定用户详细信息以获取其相关信息。...
    99+
    2024-05-14
    oracle
  • oracle备份数据库怎么用
    可以通过使用 rman、data pump 或 sql 语句来备份 oracle 数据库。推荐使用 rman,它提供了增量、并发、压缩和加密备份。步骤如下:1. 使用 rman 进行备份...
    99+
    2024-05-30
    oracle 数据丢失
  • oracle数据库和mysql数据库怎么选择
    oracle 和 mysql 数据库的选择取决于应用程序需求。oracle 数据库适合关键任务应用程序,需要企业级功能、高性能和强安全性的关键任务应用程序;mysql 数据库适合预算有限...
    99+
    2024-05-10
    mysql oracle 敏感数据
  • oracle怎么建数据库
    要建立一个Oracle数据库,你可以按照以下步骤进行操作:1. 安装Oracle软件:首先,你需要在你的计算机上安装Oracle数据...
    99+
    2023-08-24
    oracle
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作