On Mon, Mar 14, 2016 at 3:31 AM, Francisco Olarte <fola...@peoplecall.com>
wrote:

> Hi;
>
> On Mon, Mar 14, 2016 at 2:53 AM, David G. Johnston
> <david.g.johns...@gmail.com> wrote:
> > On Sunday, March 13, 2016, Ken Tanzer <ken.tan...@gmail.com> wrote:
> ....
> > Typically if I'm going to format any currency amount with pennies I would
> > format all values, even those with zero pennies, to the same precision.
> > Typically when displaying such amounts I'd right-justify the values and
> thus
> > cause the decimals to line up.
>
> But a right-aligning string output routine needs to be used.
>
>
> cdrs=> select val, tc, '"'||tc||'"' as quoted,
> '"'||regexp_replace(tc,'\.$','   ')||'"' as replaced from (select val,
> to_char(val::decimal(6,2),'FM999,990D99') as tc from (values
> (1234),(1.05),(0)) as v(val)) as w;
>  val  |   tc   |  quoted  |  replaced
> ------+--------+----------+------------
>  1234 | 1,234. | "1,234." | "1,234   "
>  1.05 | 1.05   | "1.05"   | "1.05"
>     0 | 0.     | "0."     | "0   "
> (3 rows)
>
> Summarising, any combination can be easily done with a single round of
> replace.
>
>
​See also:

http://www.postgresql.org/docs/9.5/interactive/functions-string.html

​
format(formatstr text [, formatarg "any" [, ...] ])

​David J.​

Reply via email to