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“

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值