标签:
Postgres 格式化函数提供一套有效的工具用于把各种数据类型(日期/时间,int,float,numeric)转换成格式化的字符串以及反过来从格式化的字符串转换成原始的数据类型。
注意:所有格式化函数的第二个参数是用于转换的模板。
表 5-7. 格式化函数 
 
表 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) | 
| DD | 一个月里的日子(01-31) | 
| D | 一周里的日子(1-7;SUN=1) | 
| W | 一个月里的周数 | 
| WW | 一年里的周数 | 
| CC | 世纪(2 位) | 
| J | Julian 日期(自公元前4712年1月1日来的日期) | 
| Q | 季度 | 
| RM | 罗马数字的月份(I-XII;I=JAN)-大写 | 
| rm | 罗马数字的月份(I-XII;I=JAN)-小写 | 
所有模板都都允许使用前缀和后缀修改器。模板里总是允许使用修改器。前缀 ‘FX‘ 只是一个全局修改器。
表 5-9. 用于日期/时间模板 to_char() 的后缀 
 
| 后缀 | 描述 | 例子 | 
|---|---|---|
| FM | 填充模式前缀 | FMMonth | 
| TH | 大写顺序数后缀 | DDTH | 
| th | 小写顺序数后缀 | DDTH | 
| FX | 固定模式全局选项(见下面) | FX Month DD Day | 
| SP | 拼写模式(还未实现) | DDSP | 
用法须知:
表 5-10. 用于 to_char(numeric) 的模板 
 
用法须知:
表 5-11. 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‘ | 
标签:
原文地址:http://www.cnblogs.com/zhengcheng/p/4187245.html