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

简单排序。

SELECTt1.USER_ID,t1.USER_NAME
FROMSYS_USER t1
ORDER BYt1.CREATE_TIME DESC

2. ORDER BY DECODE 指定值排序

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

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

SELECTt1.USER_ID,t1.USER_NAME,t1.USER_STATUS
FROMSYS_USER t1
ORDER BYDECODE(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

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

SELECTt1.USER_ID,t1.USER_NAME,t1.SCORE,RANK() OVER (ORDER BY t1.SCORE DESC) AS SCORE_RANK
FROMSYS_USER t1

在这里插入图片描述

2. DENSE RANK 密集排名

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

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

SELECTt1.USER_ID,t1.USER_NAME,t1.SCORE,DENSE RANK() OVER (ORDER BY t1.SCORE DESC) AS SCORE_RANK
FROMSYS_USER t1

在这里插入图片描述


四、限制条数

1. ROWNUM 限制

WHERE ROWNUM <= n

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

SELECTt1.USER_ID,t1.USER_NAME
FROMSYS_USER t1
WHEREROWNUM <= 5

2. FETCH 限制

FETCH FIRST n ROWS ONLY

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

SELECTt1.USER_ID,t1.USER_NAME
FROMSYS_USER t1
ORDER BYt1.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 函数。|| 可以用于连接字符串、数字或日期等不同类型的数据。

SELECTt1.USER_ID,t1.USER_NAME || '=' || t1.SCORE
FROMSYS_USER t1

3. CONCAT 字符串拼接

CONCAT(CONCAT(str1, str2), str3)

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

SELECTt1.USER_ID,CONCAT(CONCAT(t1.USER_NAME, '='), t1.SCORE)
FROMSYS_USER t1

4. INSTR 字符串包含

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

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

<!-- 查询姓名包含‘王’的用户 -->
SELECTt1.USER_ID,t1.USER_NAME
FROMSYS_USER t1
WHEREINSTR(t1.USER_NAME, '王') > 0
<!-- 查询姓名包含‘王’的所有用户数量 -->
SELECTINSTR(t1.USER_NAME, '王') AS NUM
FROMSYS_USER t1

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

<!-- 查询姓名包含在逗号分隔的筛选条件中的所有用户 -->
SELECTt1.USER_ID,t1.USER_NAME
FROMSYS_USER t1
WHEREINSTR(',' || #{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’ 表示多行模式等。)。

SELECTt1.USER_ID,t1.USER_NAME
FROMSYS_USER t1
WHEREt1.USER_NAME IN (SELECTREGEXP_SUBSTR(#{query.Names}, '[^,]+', 1, LEVEL)FROMDUALCONNECT BYREGEXP_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.rhkb.cn/news/416306.html

如若内容造成侵权/违法违规/事实不符,请联系长河编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

【Qt】颜色对话框QColorDialog

颜色对话框QColorDialog 颜⾊对话框的功能是允许⽤⼾选择颜⾊。继承⾃ QDialog 类。 Qt QColorDialog 的功能就是内置了调色板&#xff0c;效果和上图画图板的调色板类似。 常用方法介绍&#xff1a; QColorDialog (QWidget *parent nullptr) //创建对象的同时设置⽗对象Q…

获取navicat已保存数据库连接的密码

打开connections.ncx&#xff0c;可以看到Passwordxxx,这是加密后的密码 解密 在线的运行工具https://tool.lu/coderunner 运行如下代码&#xff0c;代码中的密码改成你的密码&#xff0c;在倒数第二行位置 <?phpnamespace FatSmallTools;class NavicatPassword{protected…

draw.io图片保存路径如何设置

当在draw.io中画图时&#xff0c;对于图片的保存经常选择了但是后面打开了又不知道图片的位置在哪&#xff0c;如下图所示&#xff0c;选择的途径很多。 为了之后存储文件较为简单&#xff0c;今天小编从源头设置图片的存储位置&#xff0c;使用浏览器设置的保存文件的路径。 …

2024年9月4日嵌入式学习

内存泄漏&#xff1a; 内存泄漏&#xff08;Memory Leak&#xff09;是指程序中已动态分配的内存由于某种原因程序未释放或无法释放&#xff0c;导致系统内存的浪费&#xff0c;严重时会导致程序运行缓慢甚至崩溃。这种情况在长时间运行的程序或大型系统中尤为常见&#xff0c;…

A02、Java编程性能调优(02)

1、Stream如何提高遍历集合效率 1.1、什么是Stream 现在很多大数据量系统中都存在分表分库的情况。例如&#xff0c;电商系统中的订单表&#xff0c;常常使用用户 ID 的 Hash 值来实现分表分库&#xff0c;这样是为了减少单个表的数据量&#xff0c;优化用户查询订单的速度。 …

2024.9.3 作业

自己实现栈和队列 代码&#xff1a; /*******************************************/ 文件名&#xff1a;sq.h /*******************************************/ #ifndef SQ_H #define SQ_H #include <iostream> #include<cstring>using namespace std; class …

Matlab R2022b使用Camera Calibrator工具箱张正友标定法进行相机标定附带标定前后对比代码

打开Camera Calibrator 在这添加你拍摄的图片 根据你每个方块的实际边长填写&#xff0c;我是15mm。 通俗一点&#xff0c;要k3就选3 Coefficients&#xff0c;否则为0&#xff1b;要p1、p2就选Tangential Distortion。然后进行计算。 可以点击右侧误差高的选中图像进行移…

【C/C++】C语言实现蛇形矩阵

目录 题目描述输入描述:输出描述:示例思路代码 题目描述 给你一个整数n&#xff0c;输出n∗n的蛇形矩阵。 输入描述: 输入一行&#xff0c;包含一个整数n 输出描述: 输出n行&#xff0c;每行包含n个正整数&#xff0c;通过空格分隔。 1<n<1000 示例 输入 4输出 …

iOS18 beta版本怎么回退至iOS17正式版本?

截止目前&#xff0c;苹果最近的iOS18的beta测试版本已经发了8版了&#xff0c;有许多朋友们都已升级提前尝鲜了&#xff0c;升级体验后许多果粉朋友们觉得有许多功能还是不够稳定&#xff0c;有些许bug&#xff0c;就想要降级&#xff0c;回退到iOS17的正式版&#xff0c;但又…

2024数博会技术成果回顾 | KPaaS助力企业数智化转型

2024年8月28日至30日&#xff0c;中国国际大数据产业博览会&#xff08;简称“数博会”&#xff09;在贵州省贵阳市隆重举行。本届数博会以“数智共生&#xff1a;开创数字经济高质量发展新未来”为主题&#xff0c;吸引了来自全球各地的400多家企业和2.1万余名嘉宾参与&#x…

AI自动生成PPT哪个软件好?如何自动生成专业级PPT?

新学期伊始&#xff0c;准备开学演讲稿的你是否还在为制作PPT而烦恼&#xff1f;别担心&#xff0c;现在有了AI的帮助&#xff0c;生成专业且吸引人的PPT变得轻而易举。 本文将为你揭秘4种高效的AI自动生成PPT的方法&#xff0c;让你在新学期的演讲中脱颖而出。无论是简洁明了…

Python | Leetcode Python题解之第391题完美矩形

题目&#xff1a; 题解&#xff1a; class Solution:def isRectangleCover(self, rectangles: List[List[int]]) -> bool:area, minX, minY, maxX, maxY 0, rectangles[0][0], rectangles[0][1], rectangles[0][2], rectangles[0][3]cnt defaultdict(int)for rect in rec…

glsl着色器学习 (十二)平移

平移和旋转、缩放是一样的&#xff0c;替换成平移矩阵即可&#xff1b; // 创建一个单位矩阵 const translateYMatrix mat4.create();// 沿着Y轴向下平移1个单位 mat4.fromTranslation(translateYMatrix, [0, -1, 0]);// 设置矩阵 gl.uniformMatrix4fv(matrixUniformLocation…

Linux进程状态 僵尸进程 孤儿进程

进程状态 R (running) Linux 的运行状态(循环空语句) S (sleeping) 阻塞状态 称为浅度睡眠(可以被唤醒)死循环打印语句时等待输入时使用 sleep 函数时 D (disk sleep) 也是一种阻塞状态&#xff0c;称为深度睡眠进程在等待磁盘写入完毕期间&#xff0c;这个进程不能被任何人杀…

2157. 优秀的拆分(power)

代码 #include<bits/stdc.h> using namespace std; int a[10001]; int main() {int n,t1,k0;bool flagfalse;cin>>n;if(n%21) {cout<<-1;return 0;}while(n>0){if(n%21){k;a[k]t; }nn/2;tt*2;}if(k>1) {flagtrue;for(int ik;i>1;i--)cout<&l…

oracle 数据库 day0823

ok了家人们&#xff0c;今天学习了orcle的基本用法&#xff0c;一日不见&#xff0c;如隔三秋啊&#xff0c; 一.多表联合查询 和之前学习的MySQL数据库一样的用法&#xff0c; 1.1 笛卡尔积查询 SELECT * FROM A表,B表 查询员工表和部门表 select * from emp e, dept d; e…

跨平台RTSP播放器之VLC Media Player还是SmartPlayer?

好多开发者纠结&#xff0c;RTSP流播放&#xff0c;到底是用开源的VLC Media Player还是大牛直播SDK的SmartPlayer&#xff1f;针对此&#xff0c;本文做个简单的技术探讨&#xff0c;方便开发者根据实际需要&#xff0c;做适合自己场景的选择&#xff1a; VLC Media Player …

flunet瞬态处理时均问题

fluent处理时均问题 最近遇到个同学&#xff0c;处理心脏跳动的时均问题&#xff0c;由于仅想取部分稳定时间段的时均数据&#xff0c;fluent的自动采样仅能对全部时间做处理&#xff0c;就存在问题了&#xff0c;网上看到两篇很详细的文章&#xff0c;记录下。 具体网址&…

截取pdf中的部分内容,又保证内容不失真,实现方式

文章目录 0.为什么需要截取pdf1.访问网站2.上传你需要截取的pdf文件3.选取区域下载 0.为什么需要截取pdf 如果直接截图工具截图的话&#xff0c;里面的文字和图片内容会出现失真的情况&#xff0c;但是我们希望pdf空白部分的内容不要&#xff0c;这个时候就需要截取pdf工具 1…

企业内部社区在企业起到什么作用?

企业内部社区是传播企业文化、促进员工互动和提升员工参与度的重要平台。通过企业内部社区&#xff0c;员工可以更好地理解和认同企业的核心价值观和文化理念&#xff0c;增强凝聚力和团队合作精神&#xff0c;进而提升企业的绩效和竞争力。企业内部社区有助于营造积极向上的工…