Postgresql/Greenplum中将数字转换为字符串TO_CHAR函数前面会多出一个空格
Posted --->别先生<---
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了Postgresql/Greenplum中将数字转换为字符串TO_CHAR函数前面会多出一个空格相关的知识,希望对你有一定的参考价值。
-- 问题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/Greenplum中将数字转换为字符串TO_CHAR函数前面会多出一个空格的主要内容,如果未能解决你的问题,请参考以下文章
查询优化 PostgreSQL (GreenPlum)。根据排名前 5 位的结果进行分组