oracle的int转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) 位(

)(参阅注解)不支持。

用法须知:

使用 'SG','PL' 或 'MI' 的带符号字并不附着在数字上面;例如,

(-12,'S9999') 生成 ,而

,,和 是 扩展。

表明一个与在 字串里面的一样的数字位数。如果没有可用的数字,那么使用一个空白(空格)。

不转换小于零的值,也不转换

。 是一个 扩展。

方便地把输入值乘以 n,这里 是跟在 后面的数字。 不支持把 与一个

点绑在一起使用(例如. "99.9V99" 是不允许的)。

表 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

总结

如果觉得编程之家网站内容还不错,欢迎将编程之家网站推荐给程序员好友。

本图文内容来源于网友网络收集整理提供,作为学习参考使用,版权属于原作者。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值