Oracleto_char格式化函数

合集下载

Oracle 获取当前日期及日期格式

Oracle 获取当前日期及日期格式
mi是分钟,输出 2009-12-25 14:23:31
select to_char(sysdate,'yyyy-MM-dd HH24:mi:ss') from dual;
mm会显示月份,输出 2009-12-25 14:12:31
select to_char(sysdate,'yyyy-MM-dd HH24:mm:ss') from dual;
yy 表示年的最后2位 、
yyy 表示年的最后3位 、
yyyy 用4位数表示年
表示month的: mm 用2位数字表示月 、
select sysdate - interval '7' day from dual;
当前时间减去7月的时间
select sysdate,sysdate - interval '7' month from dual;
当前时间减去7年的时间
select sysdate,sysdate - interval '7' year from dual;
dy 当周第几天,简写, 比如星期五或者fri 、
day 当周第几天,全称, 比如星期五或者friday
表示hour的:hh 2位数表示小时 12进制 、
hh24 2位数表示小时 24小时
时间间隔乘以一个数字
select sysdate,sysdate - 8*interval '7' hour from dual;
含义解释:
Dual伪列
Dual 是 Oracle中的一个实际存在的表,任何用户均可读取,常用在没有目标表的select语句块中。

Oracle中TO_DATE、TO_CHAR详解

Oracle中TO_DATE、TO_CHAR详解

TO_CHAR 是把日期或数字转换为字符串TO_DATE 是把字符串转换为数据库中得日期类型转换函数TO_NUMBER 将字符转化为数字? TO_CHAR使用TO_CHAR函数处理数字TO_CHAR(number, '格式')TO_CHAR(salary,’$99,999.99’);使用TO_CHAR函数处理日期TO_CHAR(date,’格式’);? TO_NUMBER使用TO_NUMBER函数将字符转换为数字TO_NUMBER(char[, '格式'])? TO_DATE使用TO_DATE函数将字符转换为日期TO_DATE(char[, '格式'])? 数字格式格式9 代表一个数字0 强制显示0$ 放置一个$符L 放置一个浮动本地货币符. 显示小数点, 显示千位指示符? 日期格式格式控制描述YYYY、YYY、YY 分别代表4位、3位、2位的数字年YEAR 年的拼写MM 数字月MONTH 月的全拼MON 月的缩写DD 数字日DAY 星期的全拼DY 星期的缩写AM 表示上午或者下午HH24、HH12 12小时制或24小时制MI 分钟SS 秒钟SP 数字的拼写TH 数字的序数词“特殊字符” 假如特殊字符HH24:MI:SS AM 15:43:20 PM日期例子:SELECT TO_DATE('2006-05-01 19:25:34', 'YYYY-MM-DD HH24:MI:SS') FROM DUAL SELECT TO_DATE('2006-05-01 19:25', 'YYYY-MM-DD HH24:MI') FROM DUAL SELECT TO_DATE('2006-05-01 19', 'YYYY-MM-DD HH24') FROM DUALSELECT TO_DATE('2006-05-01', 'YYYY-MM-DD') FROM DUALSELECT TO_DATE('2006-05', 'YYYY-MM') FROM DUALSELECT TO_DATE('2006', 'YYYY') FROM DUAL日期说明:当省略HH、MI和SS对应的输入参数时,Oracle使用0作为DEFAULT值。

oracle年月日时分秒的格式

oracle年月日时分秒的格式

Oracle年月日时分秒的格式一、概述在数据库系统中,日期和时间的处理是非常重要的一个方面。

Oracle数据库提供了丰富的日期和时间函数,可以满足不同的需求。

其中,日期和时间的格式化是其中的关键操作之一。

在Oracle中,我们可以使用不同的格式来表示年月日时分秒。

本文将详细介绍Oracle中年月日时分秒的格式化方法。

二、日期和时间的数据类型在Oracle数据库中,日期和时间被定义为特殊的数据类型。

主要的数据类型有DATE、TIMESTAMP和TIMESTAMP WITH TIME ZONE等。

这些数据类型可以存储年月日时分秒的信息。

2.1 DATE数据类型DATE数据类型是Oracle中最常用的日期和时间数据类型。

它可以存储从公元前4712年到公元9999年的日期和时间。

DATE数据类型的格式默认为”YYYY-MM-DD HH24:MI:SS”,其中YYYY表示年份,MM表示月份,DD表示日期,HH24表示小时(24小时制),MI表示分钟,SS表示秒钟。

2.2 TIMESTAMP数据类型TIMESTAMP数据类型是Oracle中用于存储日期和时间信息的另一种数据类型。

它可以存储更精确的时间信息,包括毫秒级别的精度。

TIMESTAMP数据类型的格式也是”YYYY-MM-DD HH24:MI:SS.FF”,其中FF表示毫秒。

2.3 TIMESTAMP WITH TIME ZONE数据类型TIMESTAMP WITH TIME ZONE数据类型是一种带有时区信息的日期和时间数据类型。

它可以存储时区偏移量,以便在不同的时区中正确地显示日期和时间。

TIMESTAMP WITH TIME ZONE数据类型的格式与TIMESTAMP数据类型相同。

三、日期和时间的格式化在Oracle数据库中,可以使用不同的函数来格式化日期和时间。

常用的函数有TO_CHAR、TO_DATE和TO_TIMESTAMP等。

3.1 TO_CHAR函数TO_CHAR函数用于将日期和时间数据类型转换为指定的字符串格式。

Oracleto_char函数的使用方法

Oracleto_char函数的使用方法

Oracleto_char函数的使⽤⽅法Oracle to_char函数的功能是将数值型或者⽇期型转化为字符型,下⾯就为您详细介绍Oracle to_char函数的使⽤,希望对您能有所帮助。

Postgres 格式化函数提供⼀套有效的⼯具⽤于把各种数据类型(⽇期/时间,int,float,numeric)转换成格式化的字符串以及反过来从格式化的字符串转换成原始的数据类型。

注意:所有格式化函数的第⼆个参数是⽤于转换的模板。

表 5-7. 格式化函数函数返回描述例⼦to_char(timestamp, text)text把 timestamp 转换成 string to_char(timestamp 'now','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(numeric '-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')表 5-8. ⽤于 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)⼀年⾥的⽇⼦(001-366)⼀个⽉⾥的⽇⼦(01-31)⼀周⾥的⽇⼦(1-7;SUN=1)⼀个⽉⾥的周数⼀年⾥的周数世纪(2 位)Julian ⽇期(⾃公元前4712年1⽉1⽇来的⽇期)季度罗马数字的⽉份(I-XII;I=JAN)-⼤写罗马数字的⽉份(I-XII;I=JAN)-⼩写所有模板都都允许使⽤前缀和后缀修改器。

oracle数据类型详解---日期型(转载)

oracle数据类型详解---日期型(转载)

oracle数据类型详解---⽇期型(转载)oracle 数据类型详解---⽇期型oracle数据类型看起来⾮常简单,但⽤起来会发现有许多知识点,本⽂是我对ORACLE⽇期数据类型的⼀些整理,都是开发⼊门资料,与⼤家分享:注:由于INTERVAL及TIME ZONE实际⽤得⽐较少,所以本⽂内容未涉及这两个⽅⾯。

1、常⽤⽇期型数据类型1.1、DATE这是ORACLE最常⽤的⽇期类型,它可以保存⽇期和时间,常⽤⽇期处理都可以采⽤这种类型。

DATE表⽰的⽇期范围可以是公元前4712年1⽉1⽇⾄公元9999年12⽉31⽇date类型在数据库中的存储固定为7个字节,格式为:第1字节:世纪+100第2字节:年第3字节:⽉第4字节:天第5字节:⼩时+1第6字节:分+1第7字节:秒+11.2、TIMESTAMP(p)这也是ORACLE常⽤的⽇期类型,它与date的区别是不仅可以保存⽇期和时间,还能保存⼩数秒,⼩数位数可以指定为0-9,默认为6位,所以最⾼精度可以到ns(纳秒),数据库内部⽤7或者11个字节存储,如果精度为0,则⽤7字节存储,与date类型功能相同,如果精度⼤于0则⽤11字节存储。

格式为:第1字节:世纪+100第2字节:年第3字节:⽉第4字节:天第5字节:⼩时+1第6字节:分+1第7字节:秒+1第8-11字节:纳秒,采⽤4个字节存储,内部运算类型为整形注:TIMESTAMP⽇期类型如果与数值进⾏加减运算会⾃动转换为DATE型,也就是说⼩数秒会⾃动去除。

1.3、DATE与TIMESTAMP类型内部存储验证1create table T2 (3 C1 DATE,4 C2 TIMESTAMP(9)5 );67insert into t(c1,c2) values(date'2010-2-12',timestamp'2010-2-12 13:24:52.234123211');8insert into t(c1,c2) values(9 to_date('2010-2-12 10:20:30','YYYY-MM-DD HH24:MI:SS'),10 to_timestamp('2010-2-12 13:24:52.123456','YYYY-MM-DD HH24:MI:SS.FF6')11 );1213 SQL>select c1,dump(c1) c1_d,c2,dump(c2) c2_d from t;C1 C1_D C2 C2_D------------------------ ---------------------------------------- ---------------------------------------- -----------------------------------------------------2010-2-12 Typ=12 Len=7: 120,110,2,12,1,1,1 12-FEB-10 01.24.52.234123211 PM Typ=180 Len=11:120,110,2,12,14,25,53,13,244,111,2032010-2-12 上午 10:20:30 Typ=12 Len=7: 120,110,2,12,11,21,31 12-FEB-10 01.24.52.123456000 PM Typ=180 Len=11:120,110,2,12,14,25,53,7,91,202,0以下是为了测试是为了验证TIMESTAMP的⼩数位存储算法:1 SQL>select c2,dump(c2,16) c2_d16 from t;C2 C2_D16---------------------------------------- --------------------------------------------------------------------------------12-FEB-10 01.24.52.234123211 PM Typ=180 Len=11: 78,6e,2,c,e,19,35,d,f4,6f,cb12-FEB-10 01.24.52.123456000 PM Typ=180 Len=11: 78,6e,2,c,e,19,35,7,5b,ca,0SQL>select to_number('0df46fcb','xxxxxxxx') mydata1,to_number('075bca00','xxxxxxxx') mydata2 from dual;MYDATA1 MYDATA2---------- ----------234123211 1234560002、常见问题2.1、如何取当前时间sysdate--返回当前系统⽇期和时间,精确到秒systimestamp--返回当前系统⽇期和时间,精确到毫秒2.2、如何进⾏⽇期运算⽇期型数据可以与数值加减得到新的⽇期,加减数值单位为天sysdate+1--取明天的当前时间sysdate-1/24--取当前时间的前⼀个⼩时SQL>select sysdate d1,sysdate+1 d2,sysdate-1/24 d3 from dual;D1 D2 D3------------------------ ------------------------ ------------------------2010-5-13 下午 10:55:16 2010-5-14 下午 10:55:16 2010-5-13 下午 09:55:162.3、如何求两个⽇期的间隔时间可以直接把两个⽇期相减,返回的单位为天,⼩时及分秒会换算成⼩数SQL>select date'2012-01-01'-sysdate from dual;DATE'2012-01-01'-SYSDATE------------------------597.0460300925932.4、如何将⽇期转字符to_char(sysdate,'YYYY-MM-DD HH24:MI:SS')2.5、如何将字符转⽇期to_date('2010-02-24 15:01:54','YYYY-MM-DD HH24:MI:SS')to_timestamp('1999-12-01 11:00:00.123456','YYYY-MM-DD HH:MI:SS.FF6')3、常⽤⽇期函数3.1、TO_CHAR(DATE,FORMATSTR)--格式化⽇期成字符SQL>select to_char(sysdate,'YYYY-MM-DD HH24:MI:SS') d1 from dual;D1------------------------2010-05-13 22:56:38TO_CHAR的其它⽤法⽰例1 SQL>SELECT TO_CHAR(date '2010-02-12', 'D') week_dayth,--周第⼏天(1-7),星期天=1,星期⼀=2,星期⼆=3,星期三=4,星期四=5,星期五=6,星期六=72 TO_CHAR(date '2010-02-12', 'DD') month_dayth,--⽉第⼏天3 TO_CHAR(date '2010-02-12', 'DDD') year_dayth,--年第⼏天4 TO_CHAR(date '2010-02-12', 'DAY') weekdayname,--英⽂星期名5 _CHAR(date '2010-02-12', 'w') month_weekth,--⽉第⼏周(0-4)6 TO_CHAR(date '2010-02-12', 'ww') year_weekth--年第⼏周(0-53)7FROM DUAL;WEEK_DAYTH MONTH_DAYTH YEAR_DAYTH WEEKDAYNAME MONTH_WEEKTH YEAR_WEEKTH---------- ----------- ---------- ----------- ------------ -----------6 12 043 FRIDAY 2 073.2、TO_DATE(CHAR,FORMATSTR) --将字符转换成⽇期to_date('2010-02-24 15:01:54','YYYY-MM-DD HH24:MI:SS')格式备注:HH表⽰12⼩时进制,HH24表⽰采⽤24⼩时进制,MM表⽰⽉份,MI表⽰分钟。

Oracle 中的 TO_DATE 和 TO_CHAR 函数

Oracle 中的 TO_DATE 和 TO_CHAR 函数

1. 日期和字符转换函数用法(to_date,to_char)select to_char(sysdate,'yyyy-mm-dd hh24:mi:ss') as nowTime from dual; //日期转化为字符串select to_char(sysdate,'yyyy') as nowYear from dual; //获取时间的年select to_char(sysdate,'mm') as nowMonth from dual; //获取时间的月select to_char(sysdate,'dd') as nowDay from dual; //获取时间的日select to_char(sysdate,'hh24') as nowHour from dual; //获取时间的时select to_char(sysdate,'mi') as nowMinute from dual; //获取时间的分select to_char(sysdate,'ss') as nowSecond from dual; //获取时间的秒select to_date('2004-05-07 13:23:44','yyyy-mm-dd hh24:mi:ss') from dual//2. select to_char( to_date(222,'J'),'Jsp') from dual显示Two Hundred Twenty-Two3. 求某天是星期几select to_char(to_date('2002-08-26','yyyy-mm-dd'),'day') from dual;星期一selectto_char(to_date('2002-08-26','yyyy-mm-dd'),'day','NLS_DATE_LANGUAGE = American') from dual;monday设置日期语言ALTER SESSION SET NLS_DATE_LANGUAGE='AMERICAN';也可以这样TO_DATE ('2002-08-26', 'YYYY-mm-dd', 'NLS_DATE_LANGUAGE = American')4. 两个日期间的天数select floor(sysdate - to_date('20020405','yyyymmdd')) from dual;5. 时间为null的用法select id, active_date from table1UNIONselect 1, TO_DATE(null) from dual;注意要用TO_DATE(null)6.月份差a_date between to_date('20011201','yyyymmdd') andto_date('20011231','yyyymmdd')那么12月31号中午12点之后和12月1号的12点之前是不包含在这个范围之内的。

mysql与oracle字符转换_sql日期和字符相互转换方法(MySQL和Oracle中)

mysql与oracle字符转换_sql日期和字符相互转换方法(MySQL和Oracle中)

mysql与oracle字符转换_sql日期和字符相互转换方法(MySQL和Oracle中)在MySQL和Oracle中,可以使用以下方法来进行SQL日期和字符之间的转换:1.在MySQL中,可以使用DATE_FORMAT(函数将日期格式化为指定的字符串格式。

例如,将日期转换为YYYY-MM-DD的字符串格式:```SELECT DATE_FORMAT(date_column, '%Y-%m-%d') ASformatted_dateFROM table_name;```可以使用STR_TO_DATE(函数将字符串解析为日期。

例如,将字符串格式的日期解析为日期类型:```SELECT STR_TO_DATE('2024-01-01', '%Y-%m-%d') AS date_value FROM dual;```2. 在Oracle中,可以使用TO_CHAR(函数将日期格式化为指定的字符串格式。

例如,将日期转换为YYYY-MM-DD的字符串格式:```SELECT TO_CHAR(date_column, 'YYYY-MM-DD') AS formatted_dateFROM table_name;```可以使用TO_DATE(函数将字符串解析为日期。

例如,将字符串格式的日期解析为日期类型:```SELECT TO_DATE('2024-01-01', 'YYYY-MM-DD') AS date_valueFROM dual;```请注意,日期格式化和日期解析的格式字符串可能在MySQL和Oracle之间略有不同。

因此,您可能需要根据具体的日期格式进行调整。

oracle保留小数位

oracle保留小数位

我使用的oracle数据库,所以有3个函数可以选择,分别是:
(1)ROUND(A/B,2)
ROUND()函数是会将计算结果进行四舍五入的,如果所需要的值需要进行四舍五入,就可以选择这个函数,可以有一个参数,也可以有两个参数;如果有两个param,第一个是你的计算表达式,第二个是需要保留的小数位数。

例子如下:
(2)TRUNC(A/B,2)
TRUNC()函数是不会将计算结果进行四舍五入的,如果所需要的值不需要进行四舍五入,就可以选择这个函数,可以有一个参数,也可以有两个参数;如果有两个param,第一个是你的计算表达式,第二个是需要保留的小数位数。

例子如下:
(3)TO_CHAR(A/B,’FM99990.99’)
TO_CHAR()是一个格式化函数,第一个参数是计算表达式,第二个参数是指定格式化的格式,如果保留两位小数则小数点后写两个99,这里的数字9代表的数字,也是一个占位符,表示该位置上以后会是一个数字,为什么小数点前面会是一个0,而不是9,是因为如果计算结果小于1,那么只会显示小数点和小数点之后的部分,前面的0会忽略掉。

  1. 1、下载文档前请自行甄别文档内容的完整性,平台不提供额外的编辑、内容补充、找答案等附加服务。
  2. 2、"仅部分预览"的文档,不可在线预览部分如存在完整性等问题,可反馈申请退款(可完整预览的文档不适用该条件!)。
  3. 3、如文档侵犯您的权益,请联系客服反馈,我们会尽快为您处理(人工客服工作时间:9:00-18:30)。

表5-8. 用于date/time 转换的模板所有模板都都允许使用前缀和后缀修改器。

模板里总是允许使用修改器。

前缀'FX' 只是一个全局修改器。

表5-9. 用于日期/时间模板to_char() 的后缀用法须知:•如果没有使用FX选项,to_timestamp和to_date忽略空白。

FX必须做为模板里的第一个条目声明。

•反斜杠("\")必须用做双反斜杠("\\"),例如'\\HH\\MI\\SS'。

•双引号('"')之间的字串被忽略并且不被分析。

如果你想向输出写双引号,你必须在双引号前面放置一个双反斜杠('\\'),例如 '\\"YYYY Month\\"'。

•to_char支持不带前导双引号('"')的文本,但是在双引号之间的任何字串会被迅速处理并且还保证不会被当作模板关键字解释(例如:'"Hello Year: "YYYY')。

表5-10. 用于to_char(numeric) 的模板用法须知:•使用'SG','PL' 或'MI' 的带符号字并不附着在数字上面;例如,to_char(-12, 'S9999') 生成' -12',而to_char(-12, 'MI9999') 生成'- 12'。

Oracle里的实现不允许在9前面使用MI,而是要求9在MI前面。

•PL,SG,和TH是 Postgres 扩展。

•9表明一个与在9字串里面的一样的数字位数。

如果没有可用的数字,那么使用一个空白(空格)。

•TH不转换小于零的值,也不转换小数。

TH是一个 Postgres 扩展。

•V方便地把输入值乘以10^n,这里n是跟在V后面的数字。

to_char不支持把V与一个小数点绑在一起使用(例如. "99.9V99" 是不允许的)。

表5-11. to_char例子补充:一,TO_CHAR(NUMBER)本函数把参数N转为一个VARCHAR2类型的数值。

N可以是NUMBER,BINARY_FLOAT,或者BINARY_DOUBLE。

如果不带格式,那么函数会把N转换为足以表示N的VARCHAR2字符串。

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

19 X xxxx 转换为16进制。

TO_CHAR(100,'XX')= 64注意事项:数值必须是大于等于0的整数。

前面只能和0或者FM组合使用.20 通过以上的例子,我们了解了各种数字的格式。

可以说格式太多样,难于记在脑子,最好是作为一个参考存在着.归类:数值类:0,9,分组类:(.),(,),D,G ,其中点好和逗号因为表示不明显,所以用小括号凸显。

货币类:$,C,L,U计算转换类:EEEE,RN,V,X正负符号:MI,PR,S其它类:B正统类:TM1.2 格式说明从上图可以看到格式是可选取的,保留字fmt也不是必须的,关键是NLSPARAM的意思,从第2-54章节(FORMAT MODELS)查看。

NLSPARAM可以是这样'NLS_NUMERIC_CHARACTERS = ''dg''NLS_CURRENCY = ''text'' NLS_ISO_CURRENCY = territory '举例:(待续)SELECT TO_CHAR(-10000, 'C99G999D99PR','NLS_NUMERIC_CHARACTERS=''._'' NLS_ISO_CURRENCY=''UNITED KINGDOM''') "Amount"FROM DUAL;结果返回:<GBP10_000.00>如果要了解可以使用的NLS_ISO_CURRENCY值,可以查询数据库的视图V_$NLS_VALID_VALUES二,TO_CHAR(CHARACTER)把NCLOB,CLOB,NCHAR转换为VARCHAR2.三,TO_CHAR(DATETIME)把日期转化为字符串.关于这个格式,没有什么太好说的。

相关文档
最新文档