Oracle to_char函数的使用方法

前端之家收集整理的这篇文章主要介绍了Oracle to_char函数的使用方法前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。

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

Postgres 格式化函数提供一套有效的工具用于把各种数据类型(日期/时间,int,float,numeric)转换成格式化的字符串以及反过来从格式化的字符串转换成原始的数据类型。
注意:所有格式化函数的第二个参数是用于转换的模板。

表 5-7. 格式化函数


函数

(timestamp,text)(timestamp 'now','HH12:MI:SS')(int,text)(125,'999')(float,text)(125.8,'999D9')(numeric,text)(numeric '-125.8','999D99S')

表 5-8. 用于 date/time 转换的模板


所有模板都都允许使用前缀和后缀修改器。模板里总是允许使用修改器。前缀 '' 只是一个全局修改器。

表 5-9. 用于日期/时间模板

() 的后缀


用法须知:

  • 如果没有使用 选项, 忽略空白。 必须做为模板里的第一个条目声明。
  • 反斜杠("")必须用做双反斜杠(""),例如
  • 双引号('"')之间的字串被忽略并且不被分析。如果你想向输出写双引号,你必须在双引号前面放置一个双反斜杠('\\"YYYY Month\\"'
  • 支持不带前导双引号('"')的文本,但是在双引号之间的任何字串会被迅速处理并且还保证不会被当作模板关键字解释(例如:)。

表 5-10. 用于

() 的模板


点点(使用本地化) 0) 位(

)(参阅注解)不支持。

用法须知:

表 5-11.

例子


(now(),'Day,HH12:MI:SS')(now(),'FMDay,05:39:18'(-0.1,'99.99')(-0.1,'FM9.99')(0.1,'0.9')(12,'9990999.9')(12,'FM9990999.9')(485,'999')(-485,'999')(485,'9 9 9')(1485,'9,999')(1485,'9G999')(148.5,'999.999')(148.5,'999D999')(3148.5,'9G999D999')(-485,'999S')(-485,'999MI')(485,'999MI')(485,'PL999')(485,'SG999')(-485,'SG999')(-485,'9SG99')(-485,'999PR')'(485,'L999')(485,'RN')(485,'FMRN')(5.2,'FMRN')(482,'999th')(485,'"Good number:"999')(485.8,'"Pre-decimal:"999" Post-decimal:" .999')(12,'99V999')(12.4,'99V999')(12.45,'99V9')

Oracle to_char函数最简单的应用:

/*1.0123--->'1.0123'*/
Select TO_CHAR(1.0123) FROM DUAL
/*123--->'123'*/
Select TO_CHAR(123) FROM DUAL

接下来再看看下面:

/*0.123 ---> '.123' */
SELEC TO_CHAR(0.123) FROM DUAL

上面的结果 '.123' 在大多数情况下都不是我们想要的结果,我们想要的应该是 '0.123'。

我们来看一下to_char函数的具体用法

TO_CHAR ( n [,fmt [,'nlsparam']] )

Oracle to_char函数将NUMBER类型的n按数值格式fmt转换成VARCHAR2类型的值。'nlsparams'指定由数值格式的元素返回的字符,包括:

.小数点字符
.组分隔符
.本地钱币符号
.国际钱币符号

变元的形式为:

'NLS_NUMERIC_CHARACTERS="dg" NLS_CURRENCY="tcxt" NLS_ISO_CURRENCY=territory'

其中d为小数点字符,g为组分隔符。

例 :TO_CHAR (17145,'L099G999','NLS_NUMERIC_CHARACTERS=".," NLS_CURRENCY="NUD"')=NUD017,145
通过上面的了解,再查看fmt的一些格式,我们可以用以下表达式得到'0.123'的值:

/*0.123 ---> ' 0.123' */
Select TO_CHAR(0.123,'0.999') FROM DUAL
/*100.12 ---> '######' */
Select TO_CHAR(100.12,'0.999') FROM DUAL
/*1.12 ---> ' 1.120' */
Select TO_CHAR(1.12,'0.999') FROM DUAL
' 0.123'是出来了,可是前面又多了一个空格。

对于 100.12 的值却是######,以及'1.12'的值变成了 '1.120'。

我们重新确定一个新的需求:

1、去空格
2、小数点最多4位,最少保留2位。

1--->'1.00';1.1--->'1.00';1.12-->'1.12';1.1234--->'1.1234';

1.12345--->'1.1235'

最终实现如下:

/*
FM :除空格
9999999.0099:允许小数点左边最大正数为7位,小数点右边最少2位,最多4位,且在第5位进行四舍五入
*/
Select TO_CHAR(123.0233,'FM9999999.0099') FROM DUAL

猜你在找的Oracle相关文章

输出