常用类型转换举例
-- 日期转字符串
select to_char(sysdate, 'yyyy-mm-dd hh24:mi:ss') from dual
-- 字符串转日期
select to_date('2012-12-13','yyyy-mm-dd') from dual
-- 数字转字符串
select to_char(123.12,'fm9999990.999') from dual
表 1-1. 格式化函数
函数 | 返回 | 描述 | 例子 |
---|---|---|---|
to_char(timestamp, text) | text | 把 timestamp 转换成 string | to_char(systimestamp,'HH12:MI:SS') |
to_char(numeric, text) | text | 把 numeric 转换成 string | to_char(numeric '-125.8', '999D99S') |
to_date(text, text) | date | 把 string 转换成 date | to_date('2012-11-20','yyyy-MM-dd') |
to_timestamp(text, text) | date | 把 string 转换成 timestamp | to_timestamp('2012-11-20','yyyy-MM-dd') |
to_number(text, text) | numeric | 把 string 转换成 numeric | to_number('12,454.8-', '99G999D9S') |
表 1-2. 用于 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)-小写 |
格式 | 简例 | 说明 |
,(逗号) | '9999,999' | 逗号,一般以千分位出现,作为分组符号使用.如果需要您也可以当作是十分位,百分位出现,可以出现N次,视乎数字的大小而定. |
.(点号) | '99.99' | 点号,不要念为"句号",句号是个圆圈,点好只能出现在小数点对应的地方.只能出现一次. |
$(美元符号) | '$999.99' | 美元.其实你可以放在任意地方(在10G下) |
0(零) | '0999.99' | 零.在对应位置返回对应的字符,如果没有则以'0'填充. |
9 | '999.99' | 9.在小数位,则表示转换为对应字符,如果没有则以0表示;在整数位,没有对应则不填充字符. |
B(空格符) | 'B999' | 没有其它特别作用,在整数部分最前面加一个空格,可以出现在任意位置. |
C(国际货币符号) | 'C9999' | 在特定的位置返回一个ISO货币符号(就是NLS_ISO_CURRENCY参数所代表的值) |
D(ISO 小数位符号) | '999D99' | 这是"点号"的国际版本(ISO),作用等同于点号,也是只能出现一次.所不同的是,数据库会根据NLS_NUMERIC_CHARACTER的参数值来设置内容.默认的这个值是点号. |
EEEE(科学计算符) | 9.9EEEE | 科学计算符号 |
G(分组符号) | 999G999 | 是逗号(,)的的ISO标准,作为分组符号使用,可以放在多个地方使用. |
L(本地货币符号) | 'L999' | 是C的本地版本.可以放在整个格式的最前面和最后面. |
MI(负号) | '9999MI' | 如果是负数,在尾部加上负号(-),如果是正数,则尾巴加上空格 |
PR(符号) | 9999PR | 是表达负数的另外一种方式.如果是正数,则头部加上空格;如果是负数,则用小简括号<>把数字包起来. |
RN(rn) | RN(rn) | 把整数(1-3999)转换为罗马字符.RN表示转为大写,rn表示小写的. |
S | '9999S' | 是12,13的综合改进版本.为整数加一个正号+,为负数加一个符号-.S在前则加在前,在后则在后. |
TM | TM9/TMe | 使用这个参数等于没有用参数to_char(number)一样,应为'tm9'是默认的格式参数. |
U | U999 | 双币符号,例如欧元.作用同11的L |
V | 999V9 | 这是个比较古怪,又不是很常使用的符号。它的作用在于做一个计算。 |
X | xxxx | 转换为16进制。 |
|
| 通过以上的例子,我们了解了各种数字的格式。可以说格式太多样,难于记在脑子,最好是作为一个参考存在着. |