-- 问题1、、Postgresql中将数字转换为字符串前面多出一个空格。
SELECT TO_CHAR('20181206' + 1, '99999999');
-- 解决1、使用如下,参数二前面加上fm就可以去掉空格了,如下:
SELECT TO_CHAR('20181206' + 1, 'fm99999999');
-- 设计思路
-- 1、使用当前的年月日生成yyyyMMdd格式的字符串
SELECT to_char(now(), 'yyyyMMdd')
-- 2、将生成的yyyyMMdd格式的字符串拼接00000
SELECT COALESCE(null, to_char(now(), 'yyyyMMdd')||'00000')
-- 3、将生成的yyyyMMdd格式的字符串拼接00000字符串转换成数字类型,然后加1
SELECT to_number(COALESCE(null, to_char(now(), 'yyyyMMdd')||'00000'), '9999999999999') + 1
-- 4、将生成的数字类型的批次号转换为字符串类型的,字符串最前面有一个空格
select to_char(to_number(COALESCE(null, to_char(now(), 'yyyyMMdd')||'00000'), '9999999999999') + 1, '9999999999999')
-- 5、将生成的数字类型的批次号转换为字符串类型的,将批次号最前面的空格去掉
select to_char(to_number(COALESCE(null, to_char(now(), 'yyyyMMdd')||'00000'), '9999999999999') + 1, 'fm9999999999999')
本文介绍在PostgreSQL中如何将数字转换为字符串时去除前导空格的方法,通过使用TO_CHAR函数并添加'fm'参数实现。同时,提供了生成日期批次号的详细步骤。
7370

被折叠的 条评论
为什么被折叠?



