oracle时间转字符串去除前导0

select to_char(trunc(sysdate, 'y'), 'fmyyyymmdd') from dual;
输出
201811

实际上,fm是作用于后面的每一个表达式的(不包括text表达式)。比如
select to_char(trunc(sysdate, 'y'), 'fmdy"000u"; ,.,.yyyymmadddddddddyyy') from dual;

输出
星期一000u; ,.,.20181公元11118
可以看到,除了"000u"以外全部去除了前导零。

无法正常生效的情况
1.fm可以作用于后面所有的表达式,但是当遇到某些表达式之后,会失去对后续表达式的效果。目前我只发现了3个。ds ts dl

select to_char(trunc(sysdate, 'y'), 'fm dl yyy') from dual;
输出
2018年01月01日 星期一 018
并没有将yyy的前导零去除。
2.同一个”Format Model Modifiers”(即fm,fx) 连续出现偶数次会失效。
select to_char(trunc(sysdate, 'y'), 'fmfmyyy') from dual;失效
select to_char(trunc(sysdate, 'y'), 'fmfmfmyyy') from dual;有效

当fm与fx同时生效时,fm优先级更高
select to_char(trunc(sysdate, 'y'), 'fxfmyyy') from dual;有效

失效后的解决方法
后面再加一个fm
select to_char(trunc(sysdate, 'y'), 'fmds fmyyy') from dual;
输出
`2018-1-1 18“

猜你喜欢

转载自blog.csdn.net/nayi_224/article/details/81112460