Используйте функцию даты, чтобы переименовать базу данных в postgres - PullRequest
0 голосов
/ 14 декабря 2018

Хотелось бы узнать, как переименовать базу данных с текущей датой

спасибо за помощь

1 Ответ

0 голосов
/ 14 декабря 2018

Вы можете использовать динамический SQL в блоке DO.Здесь я использую суффикс даты в формате YYYYMMDD для имени базы данных.

knayak=# CREATE DATABASE mydatabase;
CREATE DATABASE

DO $$
BEGIN

 EXECUTE format('ALTER DATABASE %I RENAME TO %I_%s', 'mydatabase','mydatabase',
                               to_char(current_date,'YYYYMMDD')::TEXT);
END
$$;

knayak=#
knayak=# \l mydatabase*
                                    List of databases
        Name         | Owner  | Encoding |   Collate   |    Ctype    | Access privileges
---------------------+--------+----------+-------------+-------------+-------------------
 mydatabase_20181214 | knayak | UTF8     | en_US.UTF-8 | en_US.UTF-8 |
(1 row)
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...