转换函数

简介: 一、日期格式说明 类型 说明 Cc 两位数字的世纪 scc 有负号的两位数字的世纪,表示世纪前 Q 表示一位数季度 yyyy 表示4位数年 iyyy 表示4位数年,ISO格式 rrrr 表示当前年的4位数字的圆整年 y,yyy ...

一、日期格式说明

类型 说明
Cc 两位数字的世纪
scc 有负号的两位数字的世纪,表示世纪前
Q 表示一位数季度
yyyy 表示4位数年
iyyy 表示4位数年,ISO格式
rrrr 表示当前年的4位数字的圆整年
y,yyy 有逗号的4位数字年
Yyy 年的最后3位数字
Yy 年的最后2位数字
Iyy 年的最后2位数字,ISO格式
Rr 基于当前年的两位数字的圆整年
Y 年的最后1位数字
I 年的最后1位数字,ISO格式
YEAR 年名称为大写字母
Year 年名称首为大写字母
Mm 两为数字月
MONTH 月名称全称,大写字母9个字符,位数不足用空格补
Month 月份的名称全程,首字母大写,9个字符,不足补空格
MON 月份名称的前3个字母,大写
Mon 月份名称的前3个字母,首字大写
RM 罗马数字月
Ww 年中的2位数字星期
Iw 年中的2位数字星期,ISO标准
W 月中的一位数字星期
ddd 年中的3位数字日
Dd 月中的两位数字日
D 周中的一位数字日
DAY 日的全称,大写字母
Day 日的全称,首字母大写
DY 日的前三个字母,大写
Dy 日的前三个字母,首字母大写
hh24 两位数字小时,24小时制
Hh 两位数字小时,12小时制
Mi 两位数字分钟
Ss 两位数字秒
ff[1...9] 小数数字秒,小数部分指定
sssss 过去12点的秒数
Ms 毫秒
Cs 厘秒
[-/,.;:] 日期时间中的分隔符
TH th 数字的后缀
SP,sp 拼读数字
SPTH,spth sp和th的组合
Tzh 时区小时
tzr 时区区域

二、数字格式说明

格式 例子 说明
, '9999,999' 逗号,一般以千分位出现,作为分组符号使用。如果需要您也可以当作是十分位,百分位出现,可以出现N次,视乎数字的大小而定。
变态的例子是 to_char(1234,'9,9,9,9')。
注意事项:只能出现在整数部分。
. '99.99' 点号,不要念为"句号",句号是个圆圈,点好只能出现在小数点对应的地方.只能出现一次.
to_char(1234.34,'9,999.99')
注意事项:只能出现在一个地方,就是原来数据小数点位置
$ '$999.99' 美元.其实你可以放在任意地方(在10G下)
to_char(1234.34,'9,999.$99') 
注意事项:只能出现一次。
0 '0999.99' 零.在对应位置返回对应的字符,如果没有则以'0'填充。
to_char(1234,'9999.00')='1234.00';
注意事项:这是一个强制的符号,对应位没有,则以'0'填充,这是9很大不同地方
9 '999.99' 9 在小数位,则表示转换为对应字符,如果没有则以0表示;在整数位,没有对应则不填充字符。
TO_CHAR(123,'999.99')=123.00;
TO_CHAR(123,'99999.9')=123.0;
注意事项:对于0和9而言,如果格式的位数不如数字的位数多,会返回'#'。
譬如to_char(12345,'9999')='#####'
B 'B999' 'B999'
没有其它特别作用,在整数部分最前面加一个空格,可以出现在任意位置.
'S'||TO_CHAR(1234,'99B99')='S 1234';
注意事项:只能出现在整数部位。
C 'C9999' 在特定的位置返回一个ISO货币符号(就是NLS_ISO_CURRENCY参数所代表的值)
TO_CHAR(1233,'C9999')='CNY1234',这是新的国际标准RMB,关于这个可查询“国际货币符号”
注意事项:只能出现在整数部位第一位。
可以通过alter session set NLS_ISO_CURRENCY='JAPAN';来修改当前会话的设置。
D '999D99' 这是“点号”的国际版本(ISO),作用等同于点号,也是只能出现一次。所不同的是,数据库会根据NLS_NUMERIC_CHARACTER的参数值来设置内容。默认的这个值是点号.
注意事项:没有特别需要一般不要用这个格式符号。也不要轻易修改参数值。
也可用alter sesssion set 来修改.
alter session set nls_numeric_characters='!';
to_char(1234.34,'9999d99')=1234!34
EEEE 9.9EEEE 科学计算符号
TO_CHAR(2008032001,'9.9EEEE')='2.01E+09',由于是科学计算方法,所以小数位前面加一个9或者0即可,多个是没有意义的。
G 999G999 是逗号(,)的的ISO标准,作为分组符号使用,可以放在多个地方使用.
TO_CHAR(123456,'999G9G99')=123,4,56
注意事项:同第八项 -D, 此外如果要转换出小数点,则要和D配合使用,不能和点号配合。
L 'L999' 是C的本地版本。可以放在整个格式的最前面和最后面.
TO_CHAR(123456,'999G9G99D00L')=123,4,56.00¥
注意事项:同第七项 C
MI '9999MI' 如果是负数,在尾部加上负号(-),如果是正数,则尾巴加上空格
to_char(1234,'9999mi')||'S'||TO_CHAR(-5678,'9999MI') =1234 S5678-
注意事项:只能放在格式尾巴
PR 9999PR 是表达负数的另外一种方式。如果是正数,则头部加上空格;如果是负数,则用小简括号<>把数字包起来.
TO_CHAR(-1234.89,'9G999D00PR')=<1,234.89>
注意事项:同上
RN(rn) RN(rn) 把整数(1-3999)转换为罗马字符。RN表示转为大写,rn表示小写的.
declare
i int;
begin
for i in 1..20 loop
dbms_output.put_line(to_char(i,'RN'));
end loop;
end;
注意事项:只能自己使用,不能和其它符号组合使用。
S '9999S' 是以上两个符号的综合改进版本。为整数加一个正号+,为负数加一个符号-。S在前则加在前,在后则在后.
TO_CHAR(-1234,'S9999')=-1234;
TO_CHAR(1234,'S9999')=+1234
TM TM9/TMe 使用这个参数等于没有用参数to_char(number)一样,应为'tm9'是默认的格式参数。
to_char(1234,'tme')=1234
注意事项:格式要么是TM9,要么是TME。
当数字长度超过64位时候,TM9的输出等同于TME的输出。
U U999 双币符号,例如欧元.作用同11的L
TO_CHAR(999,'U999')=¥999
注意事项:通过NLS_DUAL_CURRENCY 控制
V 999V9 这是个比较古怪,又不是很常使用的符号。它的作用在于做一个计算。
例如TO_CHAR(N,'999V9'),以p表示V的位置,则该表达式=to_char(N×(10的P-1次方))。但是9个数又必须保证大于等于乘积之后表示的位数。
TO_CHAR(5,'9V')=5*1=5;
TO_CHAR(5,'9V9')=5*10=50
TO_CHAR(5,'9V99')=500
TO_CHAR(50,'9V99')='######' 9的个数不够
注意事项:格式中不能和小数表达写在一起,但是可以混合货币等。
X xxxx 转换为16进制。
TO_CHAR(100,'XX')= 64
注意事项:数值必须是大于等于0的整数。前面只能和0或者FM组合使用。

三、隐式转换

1、日期:样式根据nls_date_format参数,一致可相互隐式转换

  a)  varchar2 -> to date

  b)  date -> to varchar2

2、数字:纯数字格式可以相互转换

  a)  varchar2 -> to number

  b)  number -> to varchar2

四、转换函数

函数 说明
TO_CHAR 语法:TO_CHAR(datatime|interval, format)
说明:将NUMBER或DATE类型的值转换为字符串
例句:
SELECT TO_CHAR(SYSDATE,'YYYY-MM-DD') FROM DUAL;
SELECT TO_CHAR(123456.78,'999,999.99') FROM DUAL;
TO_DATE 语法:TO_DATE(str, format)
说明:将NUMBER、CHAR或VARCHAR2转换为DATE类型值
例句:
SELECT TO_DATE('1988-07-19','YYYY-MM-DD') FROM DUAL;
TO_NUMBER 语法:TO_NUMBER(str, format)
说明:将CHAR或VARCHAR2转换为一个数值
例句:
SELECT TO_DATE('1988-07-19','YYYY-MM-DD') FROM DUAL;

目录
相关文章
|
SQL 存储 NoSQL
SQL、NoSQL还是NewSQL
【7月更文挑战第5天】SQL、NoSQL还是NewSQL
279 1
|
SQL Oracle 关系型数据库
一文入门Dataphin实时集成
Dataphin实时集成的读取和写入原理是什么?Dataphin实时集成和实时研发的区别是什么?Dataphin实时集成有哪些优势?本文一次讲清
497 1
|
数据采集 安全 数据处理
Python采集数据处理:利用Pandas进行组排序和筛选
使用Python的Pandas库,结合亿牛云代理和多线程技术,提升网络爬虫数据处理效率。通过代理IP避免封锁,多线程并发采集,示例代码展示数据分组、排序、筛选及代理IP配置和线程管理。
265 0
Python采集数据处理:利用Pandas进行组排序和筛选
|
存储 缓存 安全
操作系统中的内存管理:技术与挑战
在数字化时代,操作系统的内存管理成为计算机科学领域中一个至关重要的技术环节。本文将深入探讨现代操作系统中内存管理的基本原理、关键技术及其面临的挑战。通过对分页、分段、虚拟存储和缓存策略等核心概念的介绍,我们旨在揭示内存管理如何优化系统性能,保障数据安全,并提高资源利用率。同时,文章还将讨论内存泄漏、碎片化以及安全性问题等当前内存管理技术所面临的主要挑战。
242 0
|
运维 Prometheus 监控
「架构」云上自动化运维及其应用
企业在云上采用自动化运维,通过Prometheus+Grafana实现监控,Ansible进行配置管理,Jenkins+GitLab+SonarQube支持CI/CD,提升效率,降低成本。关键指标包括系统可用性、故障恢复时间等。通过自动化监控、配置管理和持续集成/部署,保证服务稳定性,促进快速迭代,确保市场竞争力。持续改进与培训是维持领先的关键。
365 0
|
vr&ar 图形学
论文介绍:3D-SceneDreamer——基于文本驱动的3D场景生成技术
【5月更文挑战第2天】3D-SceneDreamer是一款文本驱动的3D场景生成工具,利用NeRF技术简化3D内容创作,通过文本描述创建室内及室外场景。该框架支持6-DOF摄像机轨迹,提高视角自由度。研究结合预训练的文本到图像模型解决3D数据稀缺问题,实现高质量、几何一致的场景生成。尽管面临文本描述精度和实际应用挑战,但该技术为3D场景生成带来显著进步。[论文链接](https://arxiv.org/pdf/2403.09439.pdf)
502 6
|
前端开发 芯片
【异步电路碎碎念1】 —— 到底什么是异步电路
【异步电路碎碎念1】 —— 到底什么是异步电路
681 0
【异步电路碎碎念1】 —— 到底什么是异步电路
|
机器学习/深度学习 编解码 数据挖掘
重大里程碑!VOLO屠榜CV任务,无需额外数据,首个超越87%的模型
近来,Transformer在CV领域遍地开花,取得了非常好的性能,指标屡创新高。但Transformer的性能距离最佳的CNN仍存在差距,不由产生出一种Transformer不过如此的感觉。
重大里程碑!VOLO屠榜CV任务,无需额外数据,首个超越87%的模型
|
数据采集 存储 搜索推荐
搜索引擎爬虫的工作原理是什么?底层原理是什么?
搜索引擎爬虫的工作原理是什么?底层原理是什么?
775 0
|
Android开发 Windows
weditor, 布局分析, 查看控件信息
weditor, 布局分析, 查看控件信息
629 0