中科院云平台架构师,专注于数字化、智能化,技术方向:云、Linux内核、AI、MES/ERP/CRM/OA、物联网、传感器、大数据、ML、微服务。
分类: Oracle
2013-08-09 22:08:58
1.格式化函数
函数 返回 描述 例子to_char (timestamp, text) | text | 把 timestamp 转换成 string | to_char (sysdate,'HH12:MI:SS') |
to_char (int, text) | text | 把 int4/int8 转换成 string | to_char (125, '999') |
to_char (float, text) | text | 把 float4/float8 转换成 string | to_char (125.8, '999D9') |
to_char (numeric, text) | text | 把 numeric 转换成 string | to_char (-125.8, '999D99S') |
to_date(text, text) | date | 把 string 转换成 date | to_date('05 Dec 2000', 'DD Mon YYYY') |
to_timestamp(text, text) | date | 把 string 转换成 timestamp | to_timestamp('05 Dec 2000', 'DD Mon YYYY') |
to_number(text, text) | numeric | 把 string 转换成 numeric | to_number('12,454.8-', '99G999D9S') |
2.1 用于 date/time 转换的模板
模板 描述HH | 一天的小时数 (01-12) |
HH12 | 一天的小时数 (01-12) |
HH24 | 一天的小时数 (00-23) |
MI | 分钟 (00-59) |
SS | 秒 (00-59) |
SSSS | 午夜后的秒 (0-86399) |
AM or A.M. or PM or P.M. | 正午标识(大写) |
am or a.m. or pm or p.m. | 正午标识(小写) |
Y,YYY | 带逗号的年(4 和更多位) |
YYYY | 年(4和更多位) |
YYY | 年的后三位 |
YY | 年的后两位 |
Y | 年的最后一位 |
BC or B.C. or AD or A.D. | 年标识(大写) |
bc or b.c. or ad or a.d. | 年标识(小写) |
MONTH | 全长大写月份名(9字符) |
Month | 全长混合大小写月份名(9字符) |
month | 全长小写月份名(9字符) |
MON | 大写缩写月份名(3字符) |
Mon | 缩写混合大小写月份名(3字符) |
mon | 小写缩写月份名(3字符) |
MM | 月份 (01-12) |
DAY | 全长大写日期名(9字符) |
Day | 全长混合大小写日期名(9字符) |
day | 全长小写日期名(9字符) |
DY | 缩写大写日期名(3字符) |
Dy | 缩写混合大小写日期名(3字符) |
dy | 缩写小写日期名(3字符) |
DDD | 一年里的日子(001-366) |
DD | 一个月里的日子(01-31) |
D | 一周里的日子(1-7;SUN=1) |
W | 一个月里的周数 |
WW | 一年里的周数 |
CC | 世纪(2 位) |
J | Julian 日期(自公元前4712年1月1日来的日期) |
Q | 季度 |
RM | 罗马数字的月份(I-XII;I=JAN)-大写 |
rm | 罗马数字的月份(I-XII;I=JAN)-小写 |
所有模板都都允许使用前缀和后缀修改器。模板里总是允许使用修改器。前缀 'FX ' 只是一个全局修改器。
2.2用于日期/时间模板 to_char () 的后缀
后缀 描述 例子FM | 填充模式前缀 | FMMonth |
TH | 大写顺序数后缀 | DDTH |
th | 小写顺序数后缀 | DDTH |
FX | 固定模式全局选项(见下面) | FX Month DD Day |
SP | 拼写模式(还未实现) | DDSP |
用法须知:
3.用于 to_char (numeric ) 的模板
模板 描述9 | 带有指定位数的值 |
0 | 前导零的值 |
. (句点) | 小数 点 |
, (逗号) | 分组(千)分隔符 |
PR | 尖括号内负值 |
S | 带负号的负值(使用本地化) |
L | 货币符号(使用本地化) |
D | 小数 点(使用本地化) |
G | 分组分隔符(使用本地化) |
MI | 在指明的位置的负号(如果数字 < 0) |
PL | 在指明的位置的正号(如果数字 > 0) |
SG | 在指明的位置的正/负号 |
RN | 罗马数字(输入在 1 和 3999 之间) |
TH or th | 转换成序数 |
V | 移动 n 位(小数 )(参阅注解) |
EEEE | 科学记数。现在不支持。 |
用法须知:
4. to_char 例子
输入 输出to_char (now(),'Day, HH12:MI:SS') | 'Tuesday , 05:39:18' |
to_char (now(),'FMDay, HH12:MI:SS') | 'Tuesday, 05:39:18' |
to_char (-0.1,'99.99') | ' -.10' |
to_char (-0.1,'FM9.99') | '-.1' |
to_char (0.1,'0.9') | ' 0.1' |
to_char (12,'9990999.9') | ' 0012.0' |
to_char (12,'FM9990999.9') | '0012' |
to_char (485,'999') | ' 485' |
to_char (-485,'999') | '-485' |
to_char (485,'9 9 9') | ' 4 8 5' |
to_char (1485,'9,999') | ' 1,485' |
to_char (1485,'9G999') | ' 1 485' |
to_char (148.5,'999.999') | ' 148.500' |
to_char (148.5,'999D999') | ' 148,500' |
to_char (3148.5,'9G999D999') | ' 3 148,500' |
to_char (-485,'999S') | '485-' |
to_char (-485,'999MI') | '485-' |
to_char (485,'999MI') | '485' |
to_char (485,'PL999') | '+485' |
to_char (485,'SG999') | '+485' |
to_char (-485,'SG999') | '-485' |
to_char (-485,'9SG99') | '4-85' |
to_char (-485,'999PR') | '<485>' |
to_char (485,'L999') | 'DM 485 |
to_char (485,'RN') | ' CDLXXXV' |
to_char (485,'FMRN') | 'CDLXXXV' |
to_char (5.2,'FMRN') | V |
to_char (482,'999th') | ' 482nd' |
to_char (485, '"Good number:"999') | 'Good number: 485' |
to_char (485.8,'"Pre-decimal:"999" Post-decimal:" .999') | 'Pre-decimal: 485 Post-decimal: .800' |
to_char (12,'99V999') | ' 12000' |
to_char (12.4,'99V999') | ' 12400' |
to_char (12.45, '99V9') | ' 125' |