zoukankan      html  css  js  c++  java
  • Oracle 格式化

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

    表 5-6. 格式化函数

    函数 返回 描述 例子
    to_char(datetime, text) text 把datetime 转换成 string to_char('now'::datetime, 'hh12:mi:ss')
    to_char(timestamp, text) text 把 timestamp 转换成 string to_char( 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(-125.8, '999d99s')
    to_datetime(text, text) datetime 把 string 转换成 datetime to_datetime('05 dec 2000 13', 'dd mon yyyy hh')
    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')

    所有格式化函数都是 format-picture (格式图)的第二个参数。

    表 5-7. 用于日期/时间 to_char() 版本的format-pictures。

    format-picture 描述
    hh 一天中的小时 (01-12)
    hh12 一天中的小时 (01-12)
    mi 分钟 (00-59)
    ss 秒 (00-59)
    ssss 过了午夜的秒 (0-86399)
    y,yyy 带逗号的年 (4 或更多位)
    yyyy 年 (4 或更多位)
    yyy 年的最后三位
    yy 年的最后两位
    y 年的最后一位
    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 世纪(两位)
    j julian 日子(从4712 bc 年一月一日以来的日子)
    q 季度
    rm 罗马数字的月份 (i-xii; i=jan)

    所有 format-pictures (格式图)允许使用后缀(后缀/前缀)。对于近似 format-picture(格式图),后缀总是有效的。'fx'只是全局前缀。

    表 5-8. 用于日期/时间 to_char() 版本的 format-pictures (格式图)后缀。

    后缀 描述 例子
    fm 填充模式-前缀 fmmonth
    th 大写顺序数-前缀 ddth
    th 小写顺序数-后缀 ddth
    fx fx - (固定模式)全局 format-picture (格式图)开关。如果没有使用这个选项 to_datetime / to_date 忽略空白。必须作为formt-picture(格式图)里的第一个项目使用。 fx month dd day
    sp 拼写模式(目前未实现) ddsp

    '\' - 必须用做双 \\,例如 '\\hh\\mi\\ss'

    '"' - 双引号之间的字串被忽略并且不被分析。如果你想向输出写 '"' 你必须用 \\",例如 '\\"yyyy month\\"'。

    text - postgresql 的 to_char() 支持不带 '"' 的文本,但是带有双引号的字串会快些并且可以保证该文本不会被解释成关键字(format-picture,格式图),例如 '"hello year: "yyyy'。

    表 5-9. 用于数字 (int/float/numeric) to_char() 版本的format-pictures (格式图)。

    格式图 描述
    9 返回指定位数的值,如果不够位数用空白代替
    0 象 9 一样,但是把空白替换成零
    . (句点) 小数点
    , (逗号) 分组(千进)分隔符
    pr 在尖括号内返回负数
    s 用负号返回负数(使用本地)
    l 货币符号(使用本地)
    d 小数点(使用本地)
    g 分组符(使用本地)
    mi 在指定位置返回负号(如果数字 < 0)
    pl 在指定位置返回正号(如果数字 > 0) postgresql 扩展
    sg 在指定位置返回正/负号(如果数字 < 0) - postgresql 扩展
    rn 返回数字的罗马数字(数字必须介于1 和 3999之间)
    th 或th 把数字转换成自然数(如果是负数或小数不转换) - postgresql 扩展
    v arg1 * (10 ^ n);- 返回一个乘以 10^n (这里 'n' 是'v'后面的数字 '9')。to_char() 不支持同时使用 'v' 和小数点,如 "99.9v99"。
    eeee 科学记数,目前不支持。

    注意:通过a sign formatted via 'sg','pl' 或 'mi' 格式化的符号数不一定是数字;to_char(-12, 's9999')生成:

     '  -12' 

    ,但是 to_char(-12, 'mi9999')生成:

     '-  12' 

    。oracle 不允许在 '9' 前面使用 'mi',在 oracle 里,它总是在 '9' 后面。.

    表 5-10. to_char()的例子

    输入 输出
    to_char(now(), 'day, hh12:mi:ss')
     'tuesday  , 05:39:18' 
    to_char(now(), 'fmday, hh12:mi:ss')
     'tuesday, 05:39:18' 
    to_char( -0.1, '99.99')
     ' -.10' 
    to_char( -0.1, 'fm9.99')
     '-.1' 
    to_char( 0.1, '0.9')
     ' 0.1' 
    to_char( 12, '9990999.9')
     '    0012.0' 
    to_char( 12, 'fm9990999.9')
     '0012' 
    to_char( 485, '999')
     ' 485' 
    to_char( -485, '999')
     '-485' 
    to_char( 485, '9 9 9')
     ' 4 8 5' 
    to_char( 1485, '9,999')
     ' 1,485' 
    to_char( 1485, '9g999')
     ' 1 485' 
    to_char( 148.5, '999.999')
     ' 148.500' 
    to_char( 148.5, '999d999')
     ' 148,500' 
    to_char( 3148.5,'9g999d999')
     ' 3 148,500' 
    to_char( -485, '999s')
     '485-'	
    to_char( -485, '999mi')
     '485-'	
    to_char( 485, '999mi')
     '485' 
    to_char( 485, 'pl999')
     '+485'	
    to_char( 485, 'sg999')
     '+485'	
    to_char( -485, 'sg999')
     '-485'	
    to_char( -485, '9sg99')
     '4-85'	
    to_char( -485, '999pr')
     '<485>' 
    to_char( 485, 'l999')
     'dm 485' 
    to_char( 485, 'rn')
     '        cdlxxxv' 
    to_char( 485, 'fmrn')
     'cdlxxxv' 
    to_char( 5.2, 'fmrn')
     'v' 
    to_char( 482, '999th')
     ' 482nd' 
    to_char( 485, '"good number:"999')
     'good number: 485' 
    to_char( 485.8, '"pre-decimal:"999" post-decimal:" .999')
     'pre-decimal: 485 post-decimal: .800' 
    to_char( 12, '99v999')
     ' 12000' 
    to_char( 12.4, '99v999')
     ' 12400' 
    to_char( 12.45, '99v9')
     ' 125' 
  • 相关阅读:
    54. 八皇后问题[eight queens puzzle]
    53. 特殊的O(n)时间排序[sort ages with hashtable]
    52. 不用+、-、×、÷做加法[add two numbers without arithmetic]
    C++基础知识面试精选100题系列(11-20题)[C++ basics]
    C++基础知识面试精选100题系列(1-10题)[C++ basics]
    洛谷 P1479 宿舍里的故事之五子棋
    洛谷 P2084 进制转换
    codevs 1700 施工方案第二季
    POJ 3278 Catch That Cow(求助大佬)
    POJ 2251 Dungeon Master
  • 原文地址:https://www.cnblogs.com/VinC/p/1991078.html
Copyright © 2011-2022 走看看