PostgreSQL
 sql >> Baza danych >  >> RDS >> PostgreSQL

Jak usunąć kropkę w to_char, jeśli liczba jest liczbą całkowitą?

Możesz utworzyć funkcję:

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)

Wariant z predefiniowanym formatem (może bardziej przydatny):

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. Database
  2.   
  3. Mysql
  4.   
  5. Oracle
  6.   
  7. Sqlserver
  8.   
  9. PostgreSQL
  10.   
  11. Access
  12.   
  13. SQLite
  14.   
  15. MariaDB
  1. SQL:Odwróć transponowanie tabeli

  2. Debuguj SQL w pgAdmin, gdy SQL zawiera zmienne

  3. Jak to_char() działa w PostgreSQL

  4. Przejście danych H2 do PostgreSQL

  5. Jak ustawić limit czasu połączenia w SQLAlchemy?