Поиск…


Альтернатива DATEADD в Postgres

  • SELECT CURRENT_DATE + '1 day'::INTERVAL
  • SELECT '1999-12-11'::TIMESTAMP + '19 days'::INTERVAL
  • SELECT '1 month'::INTERVAL + '1 month 3 days'::INTERVAL

Comma разделяет значения столбца

SELECT 
    string_agg(<TABLE_NAME>.<COLUMN_NAME>, ',') 
FROM 
    <SCHEMA_NAME>.<TABLE_NAME> T

Удаление дубликатов записей из таблицы postgres

DELETE 
    FROM <SCHEMA_NAME>.<Table_NAME> 
WHERE 
    ctid NOT IN
        (
        SELECT 
            MAX(ctid) 
        FROM 
            <SCHEMA_NAME>.<TABLE_NAME> 
        GROUP BY 
            <SCHEMA_NAME>.<TABLE_NAME>.*
        )
;

Обновить запрос с объединением двух альтернативных таблиц, поскольку Postresql не поддерживает соединение в запросе обновления.

    update <SCHEMA_NAME>.<TABLE_NAME_1> AS A
    SET <COLUMN_1> = True       
    FROM <SCHEMA_NAME>.<TABLE_NAME_2> AS B 
    WHERE 
        A.<COLUMN_2> = B.<COLUMN_2> AND
        A.<COLUMN_3> = B.<COLUMN_3>

Разница между двумя датами даты по месяцам и годам

Месячная разница между двумя датами (временная метка)

select 
    (
        (DATE_PART('year', AgeonDate) - DATE_PART('year', tmpdate)) * 12 
        +
        (DATE_PART('month', AgeonDate) - DATE_PART('month', tmpdate))
    ) 
from dbo."Table1"

Разница в два раза между двумя датами (временная метка)

select (DATE_PART('year', AgeonDate) - DATE_PART('year', tmpdate)) from dbo."Table1"

Запрос на копирование / перемещение / перенос данных таблицы из одной базы данных в другую таблицу базы данных с той же схемой

Первое исполнение

CREATE EXTENSION DBLINK;

затем

INSERT INTO 
    <SCHEMA_NAME>.<TABLE_NAME_1> 
SELECT * 
FROM 
    DBLINK(
    'HOST=<IP-ADDRESS> USER=<USERNAME> PASSWORD=<PASSWORD> DBNAME=<DATABASE>',
    'SELECT * FROM <SCHEMA_NAME>.<TABLE_NAME_2>')
    AS <TABLE_NAME>
    (
    <COLUMN_1> <DATATYPE_1>, 
    <COLUMN_1> <DATATYPE_2>, 
    <COLUMN_1> <DATATYPE_3>
    );


Modified text is an extract of the original Stack Overflow Documentation
Лицензировано согласно CC BY-SA 3.0
Не связан с Stack Overflow