#TO_NUMBER

to_number
TO_NUMBER ( expr , format )

TO_NUMBER函数将expr的值按format格式转换为NUMBER类型的数据。

expr值的数据类型可以为:

  • 数值型:此时不需要指定format,函数直接转换为NUMBER类型。
  • 字符型:此时函数将根据format格式转换,且expr内容需符合指定的format格式。

当expr的值为NULL时,函数返回NULL。

format

指定转换的格式,支持以下字符的组合:

  • 小数点:.,例如'99.99'
  • 美元符号:$,例如'$9,999'
  • 强迫零显示:0,例如'00000'
  • 指定位置返回数字:9,例如'9999'
  • 指定位置返回小数点:D,例如'99D99'
  • 设首位或末尾为-或+:S,例如'S9999'
  • 千位分隔符:,,例如'9,999'
  • 在指定位置返回千位分隔符:G,例如'9G9'

(以下为列存表专用格式)

  • 当整数部分为零时,返回定点数字整数部分的空格:B,例如'B99'
  • 在指定位置返回货币符号:C,例如'C99'
  • 以科学计数法的形式返回数字:EEEE,例如'9EEEE'
  • 在指定位置显示货币符号:L,例如'L99'
  • 负值末尾填充负号,正值末尾填充空格:MI,例如'9MI'
  • 负值放在<>中,正值首尾填充空格:PR,例如'9PR'
  • 返回大写罗马数字形式:RN,例如'RN'
  • 返回小写罗马数字形式:rn,例如'RN'
  • 以最少的字符数返回十进制数字字符串:TM,例如'TM'
  • 在指定位置返回欧元等货币符号:U,例如'U99'
  • 返回10n值,其中n是V后面的数字:V,例如'99V99'
  • 返回指定数字的十六进制值:X,例如'XXX'
  • 去掉前后空格和小数后面多余的0:FM,例如'FM999'

示例

--将所有数据转化为NUMBER类型输出,此数据的显示宽度与SET NUMWIDTH有关
SELECT TO_NUMBER(numbera) n1,
TO_NUMBER(numberb) n2,
TO_NUMBER(numberc) n3,
TO_NUMBER(numberd) n4,
TO_NUMBER(numbere) n5,
TO_NUMBER(numberf) n6,
TO_NUMBER(numberg) n7
FROM numbers;
        N1          N2          N3          N4          N5          N6          N7       
----------- ----------- ----------- ----------- ----------- ----------- ----------- 
         -5          55        5555  5.5556E+18  5.55499983  -5.5555556         555       
pdf-btn 下载文档
copy-btn 复制链接