当前位置: 首页 > article >正文

Oracle 常用函数大全

文章目录

  • 一、空校验
    • 1. NVL 空校验
    • 2. COALESCE 空校验
  • 二、排序
    • 1. ORDER BY 排序
    • 2. ORDER BY DECODE 指定值排序
  • 三、排名
    • 1. RANK 排名
    • 2. DENSE RANK 密集排名
  • 四、限制条数
    • 1. ROWNUM 限制
    • 2. FETCH 限制
  • 五、字符串处理
    • 1. TO_CHAR 字符串转换
    • 2. || 字符串拼接
    • 3. CONCAT 字符串拼接
    • 4. INSTR 字符串包含
    • 5. REGEXP_SUBSTR 正则截取字符串
  • 六、日期处理
    • 1. TO_DATE 日期转换
  • 其他
    • LISTAGG 多行拼接
    • ROUND 四舍五入
    • LISTAGG
    • REGEXP_SUBSTR
    • REGEXP_REPLACE
    • CONNECT BY
    • OVER
    • TRUNC


一、空校验

1. NVL 空校验

NVL(exp1, exp2) :若 exp1 不为 NULL,则返回 exp1;若 exp1 为 NULL,则返回 exp2。

无论 exp1 是否为 NULL ,均会计算 exp2。

2. COALESCE 空校验

COALESCE(exp1, exp2, …, expn) :返回第一个非空表达式,如果全是 NULL,则返回 NULL。

顺序计算表达式的值,直到不为 NULL。


二、排序

1. ORDER BY 排序

ORDER BY column ASC

简单排序。

SELECT
	t1.USER_ID,
	t1.USER_NAME
FROM
	SYS_USER t1
ORDER BY
	t1.CREATE_TIME DESC

2. ORDER BY DECODE 指定值排序

ORDER BY DECODE(column, ‘特定值1’, 1, ‘特定值2’, 2, …, ‘其他值’, n) ASC

指定特定值的权重进行排序。

SELECT
	t1.USER_ID,
	t1.USER_NAME,
	t1.USER_STATUS
FROM
	SYS_USER t1
ORDER BY
	DECODE(t1.USER_STATUS, '特定值1', 1, '特定值2', 2, ..., '其他值', n) ASC

在这个例子中,USER_STATUS 中 ‘特定值1’ 的排序权重为1,‘特定值2’ 的排序权重为2,依此类推,并指定 ASC 顺序排序。


三、排名

1. RANK 排名

RANK() OVER (ORDER BY column DESC) AS column_rank

用于字段排名。多行数据的字段值相同时,排名相同。当前排名 = 上一个排名 + 上一个排名的总记录数。

SELECT
	t1.USER_ID,
	t1.USER_NAME,
	t1.SCORE,
	RANK() OVER (ORDER BY t1.SCORE DESC) AS SCORE_RANK
FROM
	SYS_USER t1

在这里插入图片描述

2. DENSE RANK 密集排名

DENSE RANK() OVER (ORDER BY column DESC) AS column_rank

用于字段排名。多行数据的字段值相同时,排名相同。当前排名 = 上一个排名 + 1。

SELECT
	t1.USER_ID,
	t1.USER_NAME,
	t1.SCORE,
	DENSE RANK() OVER (ORDER BY t1.SCORE DESC) AS SCORE_RANK
FROM
	SYS_USER t1

在这里插入图片描述


四、限制条数

1. ROWNUM 限制

WHERE ROWNUM <= n

只获取 n 条记录。ROWNUM 写在 WHERE 条件中,只能获取 n 条记录后再进行 ORDER BY 排序,无法在 ORDER BY 排序后获取前 n 条记录。

SELECT
	t1.USER_ID,
	t1.USER_NAME
FROM
	SYS_USER t1
WHERE
	ROWNUM <= 5

2. FETCH 限制

FETCH FIRST n ROWS ONLY

只获取前 n 条记录。可以在 ORDER BY 排序后获取前 n 条记录。

SELECT
	t1.USER_ID,
	t1.USER_NAME
FROM
	SYS_USER t1
ORDER BY
	t1.CREATE_TIME DESC
FETCH FIRST 5 ROWS ONLY

五、字符串处理

1. TO_CHAR 字符串转换

TO_CHAR(SYSDATE, ‘YYYY-MM-DD HH24:MI:SS’)

参数1:转换的对象(数字、日期或时间戳)。
参数2:格式模型(可选),指定如何格式化转换后的字符串。

SELECT 
	TO_CHAR(SYSDATE, 'YYYY-MM-DD HH24:MI:SS')
FROM 
	SYS_USER t1

2. || 字符串拼接

str1 || str2 || …

|| 将 NULL 视为一个空字符串。|| 运算符优先级高于 CONCAT 函数。|| 可以用于连接字符串、数字或日期等不同类型的数据。

SELECT
	t1.USER_ID,
	t1.USER_NAME || '=' || t1.SCORE
FROM
	SYS_USER t1

3. CONCAT 字符串拼接

CONCAT(CONCAT(str1, str2), str3)

如果任何输入字符串为 NULL,CONCAT 返回 NULL。Oracle 的 CONCAT 函数只允许两两字符串拼接。

SELECT
	t1.USER_ID,
	CONCAT(CONCAT(t1.USER_NAME, '='), t1.SCORE)
FROM
	SYS_USER t1

4. INSTR 字符串包含

INSTR(源字符串, 目标字符串, 起始位置, 匹配序号)。

例如:INSTR(‘string’, ‘in’, -1, 1) 。源字符串为 ‘string’,目标字符串为 ‘in’,查询起始位置为 -1(可省略,默认 -1),取第 1 个匹配项的位置(可省略,默认 1)。

<!-- 查询姓名包含‘王’的用户 -->
SELECT
	t1.USER_ID,
	t1.USER_NAME
FROM
	SYS_USER t1
WHERE
	INSTR(t1.USER_NAME, '王') > 0
<!-- 查询姓名包含‘王’的所有用户数量 -->
SELECT
	INSTR(t1.USER_NAME, '王') AS NUM
FROM
	SYS_USER t1

实现与 MySQL 函数 FIND_IN_SET 相同用法,即根据逗号分隔的筛选条件进行查询:

<!-- 查询姓名包含在逗号分隔的筛选条件中的所有用户 -->
SELECT
	t1.USER_ID,
	t1.USER_NAME
FROM
	SYS_USER t1
WHERE
	INSTR(',' || #{query.Names} || ',', ',' || t1.USER_NAME || ',') > 0

但是 INSTR 会导致索引失效,查询效率较低,建议转换成 IN 查询。

5. REGEXP_SUBSTR 正则截取字符串

REGEXP_SUBSTR(源字符串, 正则表达式 [, 开始位置 [, 匹配序号 [, 匹配模式 ] ] ] )

例如:REGEXP_SUBSTR(‘string’, ‘[^,]+’, 1, 1, ‘c’)。源字符串为 ‘string’,正则表达式为 ‘[^,]+’,开始搜索的位置为 1(可省略,默认 1),返回第一个匹配项(可省略,默认 1),‘c’ 表示区分大小写(可省略,默认 ‘c’。‘i’ 表示不区分大小写,‘c’ 表示区分大小写,‘n’ 表示不匹配换行符,‘m’ 表示多行模式等。)。

SELECT
	t1.USER_ID,
	t1.USER_NAME
FROM
	SYS_USER t1
WHERE
	t1.USER_NAME IN (
		SELECT
			REGEXP_SUBSTR(#{query.Names}, '[^,]+', 1, LEVEL)
		FROM
			DUAL
		CONNECT BY
			REGEXP_SUBSTR(#{query.Names}, '[^,]+', 1, LEVEL) IS NOT NULL
    )

六、日期处理

1. TO_DATE 日期转换

其他

LISTAGG 多行拼接

LISTAGG( 待处理列, 连接符号 ) WITHIN GROUP(ORDER BY 拼接排序依据字段)
col:待处理列。
连接符号
拼接排序依据字段。

ROUND 四舍五入

ROUND(number,num_digits)

number 需要进行四舍五入的数字。
num_digits 指定需要四舍五入的小数位数。

LISTAGG

REGEXP_SUBSTR

REGEXP_REPLACE

CONNECT BY

OVER

TRUNC


http://www.kler.cn/a/290307.html

相关文章:

  • Objective-C语言的软件工程
  • 【ROS2】Qt事件循环和ROS2订阅机制一起使用有什么注意事项?
  • gesp(C++四级)(11)洛谷:B4005:[GESP202406 四级] 黑白方块
  • 计算机网络 (32)用户数据报协议UDP
  • 高通,联发科(MTK)等手机平台调优汇总
  • STM32+WIFI获取网络时间+8位数码管显示+0.96OLED显
  • 深入理解区间调度问题:从贪心算法到动态规划的加权优化
  • SprinBoot+Vue实验室考勤管理微信小程序的设计与实现
  • UEFI开发——编写一个简单的PPI
  • FFmpeg源码:avcodec_descriptor_get函数分析
  • Flutter 仿iOS桌面悬浮球效果
  • 【数学建模备赛】Ep07:灰色预测模型
  • 随手笔记【五】
  • 【扇贝编程】使用Selenium模拟浏览器获取动态内容笔记
  • AI证件照生成神器颠覆传统,轻松驾驭考研、考公与签证申请
  • PHP + Redis 实现抽奖算法(ThinkPHP5)
  • Spring6梳理6——依赖注入之Setter注入
  • 【drools】Rulesengine构建及intelj配置
  • 通过组合Self-XSS + CSRF得到存储型XSS
  • 跨境电商代购系统中前台基本功能介绍:帮助更快的了解跨境代购业务
  • 注册登陆(最新版)
  • IOS 18 发现界面(UITableView)Banner轮播图实现
  • 【话题】提升开发效率的秘密武器:探索高效编程工具
  • SpinalHDL之BlackBox(下篇)
  • C#如何使用外部别名Extern alias
  • 单向链表与双向链表