sql >> Database teknologi >  >> RDS >> PostgreSQL

Sådan fjerner du prikken i to_char, hvis tallet er et heltal

Du kan oprette en funktion:

create function to_ch (value numeric, format text)
returns text language sql as $$
    select rtrim(to_char(value, format), '.')
$$;

select to_ch(1.2, 'FM9999.9999'), to_ch(1, 'FM9999.9999'), to_ch(1.2212, 'FM9999.9999');

 to_ch | to_ch | to_ch  
-------+-------+--------
 1.2   | 1     | 1.2212
(1 row)

Variant med foruddefineret format (måske mere praktisk):

create function to_ch4 (value numeric)
returns text language sql as $$
    select rtrim(to_char(value, 'FM9999.9999'), '.')
$$;

select to_ch4(1.2), to_ch4(1), to_ch4(1.2212);

 to_ch4 | to_ch4 | to_ch4 
--------+--------+--------
 1.2    | 1      | 1.2212
(1 row)



  1. MySQL behandler ÅÄÖ som AAO?

  2. LINQ Brug like i stedet for (( NVL(INSTR(x, y), 0) ) =1)

  3. SQL Server 2008 Spatial:find et punkt i polygon

  4. To fremmednøgler i samme kolonne fra en tabel