oracle 常用函数的应用

news2025/4/25 12:31:40

在使用开发中会经常遇到数据类型转换、显示系统时间等情况,需要使用函数来实现。通过函数来实现业务需求会非常的省事便捷,函数可以用在适当的dml语句和查询语句中。
Oracle 数据库中主要使用两种类型的函数:
(1)单行函数:对每一个函数应用在表的记录中时,只能输入一行结果,返回一个结果, 比如:MOD(x,y)返回 x 除以 y 的余数(x 和 y 可以是两个整数,也可以是表中的整 数列)。常用的单行函数有:
字符函数:对字符串操作。
数字函数:对数字进行计算,返回一个数字。
转换函数:可以将一种数据类型转换为另外一种数据类型。
日期函数:对日期和时间进行处理。
(2)聚合函数:聚合函数同时可以对多行数据进行操作,并返回一个结果。
本章介绍一些Oracle系统自带的常用转换函数、日期函数、分组函数。

6.1常用函数
6.1.1转换字符函数to_char()
To_char()函数是将数值型或日期型转化为字符型。
具体使用格式如下:
to_char (input_value,format_code)
input_value:需要转换的字段。
format_code:转换后的格式。
【例6-1】建立产品信息表,包括产品名称、产品单价、库存数、最后进货日期、
将最后一次进货时间用完整时间方式显示。把产品单价转换成字符型。
建表代码如下:
–第六章
–建立产品信息表
CREATE TABLE plsql101_product (
product_name varchar2(25),
product_price NUMBER(4,2),
quantity_on_hand NUMBER(5,0),
last_stock_date DATE
)
–插入数据
INSERT INTO PLSQL101_PRODUCT
select ‘Small Widget’,500,30 ,to_date(‘20220902’,‘yyyymmdd’) from dual;
INSERT INTO PLSQL101_PRODUCT
select ‘Medium Wodge’,800,600 ,to_date(‘20220806’,‘yyyymmdd’)from dual;
INSERT INTO PLSQL101_PRODUCT
select ‘Chrome Phooba’,650,120 ,to_date(‘20220716’,‘yyyymmdd’)from dual;
Commit;

将最后一次进货时间用完整时间方式显示,代码如下:
select PRODUCT_NAME,
PRODUCT_PRICE,
QUANTITY_ON_HAND,LAST_STOCK_DATE,
to_char(LAST_STOCK_DATE, ‘yyyy-mm-dd,HH24:MI’)
from PLSQL101_PRODUCT;
查询结果如图6-1所示。
在这里插入图片描述

图6-1查询产品信息表数据
把产品单价转换成字符型,代码如下:
SELECT product_name,
TO_CHAR(product_price, ‘$9,999.00’) “Price”,
quantity_on_hand,
last_stock_date
FROM plsql101_product;
查询结果如图6-2所示。
在这里插入图片描述

图6-2查询产品信息表数据
6.1.2 转换日期函数to_date()
to_date函数格式如下:
TO_DATE(input_value,format_code)
input_value:需要转换的字段。
format_code:转换后的格式。
【例6-2】把产品名称为Small Widget的最后一次进货时间更新为2022年9月10日下午4点半。
更新产品信息表,代码如下:
–第六章\hs.sql

UPDATE plsql101_product
SET last_stock_date = TO_DATE(‘2022/09/10 16:30:30’ ,‘yyyy/mm/dd hh24:mi:ss’)
WHERE product_name=‘Small Widget’;
Commit;
–查询数据
Select * from plsql101_product;

查询结果如图6-3所示。
在这里插入图片描述

图6-3查询更新后产品信息表数据
6.1.3decode()函数
Decode函数的格式如下:
DECODE(条件,值1,翻译值1,值2,翻译值2,…值n,翻译值n,缺省值)
该函数的含义如下:
IF 条件=值1 THEN
    RETURN(翻译值1)
ELSIF 条件=值2 THEN
    RETURN(翻译值2)
    …
ELSIF 条件=值n THEN
    RETURN(翻译值n)
ELSE
    RETURN(缺省值)
END IF

【例6-3】建立雇员部门信息表,包括雇员编号、部门编号、部门名称 。把部门编号为10的记录部门名称更新成为财务。部门编号为20的记录更新部门为公关,部门编号为空的更新成未知。
建表插入测试数据,代码如下:
–第六章\hs.sql

create table sm_emp_dept
(id char(10),
deptno char(2),
dept varchar2(20));

insert into sm_emp_dept(id,deptno) values(‘001’,‘10’);
insert into sm_emp_dept(id,deptno) values(‘002’,‘20’);
insert into sm_emp_dept(id,deptno) values(‘003’,‘10’);
insert into sm_emp_dept(id,deptno) values(‘007’,null);
insert into sm_emp_dept(id,deptno) values(‘008’,‘80’);
Commit;
先查询数据,代码如下:
select * from sm_emp_dept t
执行后如图6-4所示。
在这里插入图片描述

图6-4查询部门信息表表数据

更新数据,代码如下:
update sm_emp_dept set dept= decode
(deptno , 10 , ‘财务’,
20 , ‘公关’,
‘未知’);
Commit;

select * from sm_emp_dept

执行查询,结果如图6-5所示。
在这里插入图片描述

图6-5查询更新后部门信息表数据

6.1.4 nvl()函数
nvl函数可以实现空值的转换,基本格式如下:
NVL(输入值,输出值)
输入值为NULL,则返回输出值,否则仍为输入值。输出值必须与输入值类型相同。

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

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

“上云入端” 浪潮云剑指组织智能化落地“最后一公里”

进入2025年,行业智能体正在成为数实融合的核心路径。2025年初DeepSeek开源大模型的横空出世,通过算法优化与架构创新,显著降低算力需求与部署成本,推动大模型向端侧和边缘侧延伸。其开源策略打破技术垄断,结合边缘计算…

CentOS 7 如何挂载ntfs的移动硬盘

CentOS 7 如何挂载ntfs的移动硬盘 前言一、查看硬盘并尝试挂载(提示无法挂载)二、yum安装epel-release提示yum被锁定三、强行终止yum的进程四、yum安装epel-release完成五、yum安装ntfs-3g六、此时可正常挂载NTFS硬盘 前言 CentOS 7默认情况下是不支持NTFS的文件系统&#xff…

pytorch+maskRcnn框架训练自己的模型以及模型导出ONXX格式供C++部署推理

背景 maskrcnn用作实例分割时,可以较为精准的定位目标物体,相较于yolo只能定位物体的矩形框而言,优势更大。虽然yolo的计算速度更快。 直接开始从0到1使用maskrCNN训练自己的模型并并导出给C部署(亲测可用) 数据标注…

①EtherCAT/Ethernet/IP/Profinet/ModbusTCP协议互转工业串口网关

型号 协议转换通信网关 EtherCAT 转 Modbus TCP MS-GW15 概述 MS-GW15 是 EtherCAT 和 Modbus TCP 协议转换网关,为用户提供一种 PLC 扩展的集成解决方案,可以轻松容易将 Modbus TCP 网络接入 EtherCAT 网络 中,方便扩展,不受限…

《Oracle服务进程精准管控指南:23c/11g双版本内存优化实战》 ——附自动化脚本开发全攻略

正在学习或者是使用 Oracle 数据库的小伙伴,是不是对于那个一直启动且及其占用内存的后台进程感到烦躁呢?而且即使是手动去开关也显得即为麻烦,所以基于我之前所学习到的方法,我在此重新整理,让大家动动手指就能完成开…

Java单列集合[Collection]

目录 1.Collection单列集合 1.1单列集合各集合特点 1.2、Collection集合 1.2.1、Collection方法 1.2.2、Collection遍历方式 1.2.2.1、迭代器遍历集合 1.2.2.2、增强for遍历集合 1.2.2.3、forEach遍历集合(JDK8之后) 1.2.2.4、遍历案例 1.3、Li…

如何在ONLYOFFICE插件中添加自定义AI提供商:以通义千问和Kimi为例

随着 ONLYOFFICE AI 插件的发布,我们极大地提升了编辑器的默认功能。在ONLYOFFICE,我们致力于提供强大且灵活的解决方案,以满足您的特定需求。其中一项便是能够在 AI 插件中添加自定义提供商。在这篇文章中,我们将展示如何将通义千…

Spark,配置hadoop集群1

配置运行任务的历史服务器 1.配置mapred-site.xml 在hadoop的安装目录下&#xff0c;打开mapred-site.xml&#xff0c;并在该文件里面增加如下两条配置。 eg我的是在hadoop199上 <!-- 历史服务器端地址 --> <property><name>mapreduce.jobhistory.address…

FPGA实现4K MIPI视频解码H265压缩网络推流输出,基于IMX317+VCU架构,支持4K60帧,提供工程源码和技术支持

目录 1、前言工程概述免责声明 2、相关方案推荐我已有的所有工程源码总目录----方便你快速找到自己喜欢的项目我这里已有的 MIPI 编解码方案我这里已有的视频图像编解码方案 3、详细设计方案设计框图FPGA开发板IMX317摄像头MIPI D-PHYMIPI CSI-2 RX Subsystem图像预处理Sensor …

【Linux】网络概念

目录 网络模型 OSI七层模型 TCP/IP五层(或四层)模型 网络传输 网络传输基本流程 封装与分用 以太网通信&#xff08;局域网传输&#xff09; 跨网络传输 网络模型 OSI七层模型 TCP/IP五层(或四层)模型 网络层和传输层就是操作系统的一部分 网络传输 网络传输基本流程…

【模拟CMOS集成电路设计】电荷泵(Charge bump)设计与仿真(示例:栅极开关CP+轨到轨输入运放+基于运放CP)

【模拟CMOS集成电路设计】电荷泵&#xff08;Charge bump&#xff09;设计与仿真 0前言1电荷泵1.1 PFD/CP/电容器级联1.2 PFD/CP/电容传递函数 2基本电荷泵(CP)结构2.1“漏极开关”结构2.2“源极开关”结构2.3“栅极开关”结构 3 CP的设计与仿真13.1 P/N电流源失配仿真3.2 电荷…

Kafka消息丢失全解析!原因、预防与解决方案

作为一名高并发系统开发工程师&#xff0c;在使用消息中间件的过程中&#xff0c;无法避免遇到系统中消息丢失的问题&#xff0c;而Kafka作为主流的消息队列系统&#xff0c;消息丢失问题尤为常见。 在这篇文章中&#xff0c;将深入浅出地分析Kafka消息丢失的各种情况&#xf…

VS Code 云服务器远程开发完整指南

VS Code Ubuntu 云服务器远程开发完整指南 远程开发是现代开发者的标配之一&#xff0c;特别是在使用云服务器&#xff08;如 Ubuntu&#xff09;进行部署、测试或大项目开发时&#xff0c;利用 VS Code 的 Remote-SSH 插件&#xff0c;可以像本地一样顺滑操作远程服务器。本…

【Rtklib入门指南】4. 使用RTKLIB进行载波相位差分定位(RTK)

RTK RTK&#xff08;Real-Time Kinematic&#xff0c;实时动态&#xff09;定位技术是一种高精度的卫星导航技术。相比传统的GPS定位技术&#xff0c;RTK能够在厘米级别的精度范围内提供定位结果。这使得RTK技术在无人机、自动驾驶、工程测绘、农业机械自动化等领域具有广泛应用…

【SECS】初识SECS协议

【SECS】初识SECS协议 基本知识流和功能函数数量官方文件中缩写标注正常是不是都是主机向设备端?对数据信息中第1字节第1-2位官网介绍 S1F1双向指令说明测试H发起端E发起端 参考资料 基本知识 SECS&#xff08;SEMI Equipment Communications Standard&#xff09;即半导体设…

【C++项目】从零实现RPC框架「三」:项⽬抽象层实现

🌈 个人主页:Zfox_ 🔥 系列专栏:C++从入门到精通 目录 一:🔥 常⽤的零碎功能接⼝类实现🦋 简单⽇志宏实现🦋 Json 序列化/反序列化🦋 UUID ⽣成二:🔥 项⽬消息类型字段信息定义 🦋 请求字段宏定义🦋 消息类型定义🦋 响应码类型定义🦋 RPC 请求类型定…

相机镜头景深

文章目录 定义影响因素实际应用特殊情况 参考&#xff1a;B站优致谱视觉 定义 景深是指在摄影机镜头或其他成像器前沿着能够取得清晰图像的成像器轴线所测定的物体距离范围。简单来说&#xff0c;就是在一张照片中&#xff0c;从前景到背景&#xff0c;能够保持清晰锐利的区域…

Linux基础入门:从零开始掌握Linux命令行操作

&#x1f64b;大家好&#xff01;我是毛毛张! &#x1f308;个人首页&#xff1a; 神马都会亿点点的毛毛张 &#x1f388;有没有觉得电影里的黑客&#x1f412;酷毙了&#xff1f;他们只用键盘⌨就能搞定一切。今天&#xff0c;毛毛张要带你们体验这种快感&#x1f600;&…

C++第13届蓝桥杯省b组习题笔记

1.九进制转十进制 九进制正整数 (2022)9转换成十进制等于多少&#xff1f; 第一位乘9的0次方&#xff0c;第二位乘9的1次方&#xff0c;第三位乘9的二次方以此类推 #include <iostream> using namespace std;int main() {// 请在此输入您的代码int t2022;int res0;int c…

python-leetcode 61.N皇后

题目&#xff1a; 按照国际象棋的规则&#xff0c;皇后可以攻击与之处在同一行或同一列或同一斜线上的棋子。 n 皇后问题 研究的是如何将 n 个皇后放置在 nn 的棋盘上&#xff0c;并且使皇后彼此之间不能相互攻击 给你一个整数 n &#xff0c;返回所有不同的 n 皇后问题 的解…