date, _enddate date)
AS
$$
DECLARE
_sql text;
loopdate date DEFAULT _begindate;
BEGIN
IF _begindate > _enddate THEN
RAISE EXCEPTION '_begindate should smaller than _end_date';
END IF;
IF _begindate is null or _enddate is null THEN
raise exception '_begindate and _enddate cannot be null';
end if;
while loopdate <= _enddate
LOOP
_sql := 'CREATE TABLE rpp_order_partition_'
|| to_char(loopdate, 'YYYYMMDD')
|| ' partition of order for values in ( '''
|| loopdate || ''')';
RAISE NOTICE '_sql: %', _sql;
EXECUTE _sql;
SELECT (loopdate + interval '1 day')
INTO loopdate;
END LOOP;
END
$$
LANGUAGE plpgsql;
которая генерирует партиции по дням, название сгенеренной партиции получается вида
rpp_order_partition_20220617
, но проблема в том, что поле по которому создана партиция имеет формат
2022-06-17 12:00:00.000000
и при вставке новой записи партиция не может быть найдена, т.к форматы дат разные, подскажите, пожалуйста, как это можно исправить? нужно чтобы при вставке записи с датой вида
2022-06-17 12:00:00.000000
она попадала в партицию
rpp_order_partition_20220617
, БД postgresql
> т.к форматы дат разные Не так как "форматы дат разные", а так как ваша дата преобразована в формат этого поля (timestamptz, видимо, кстати, зачем мне его угадывать?) -- и получилась ровно одна микросекунда в полночь этой даты. А указывать надо интэрвалы времени. (Точнее, конечно, не надо. Поскольку партицыонирование в postgres не очень хорошэе, и навредить можэт очень легко. Потому в подавляющем большынстве случаев новички только создают себе проблемы попыткой партицыонировать postgres).
да, верно, формат поля timestamp, забыл на это указать не очень понял про микросекунды, в сообщении дату 2022-06-17 12:00:00.000000 указал для примера, она может иметь любой вид - 2022-06-17 12:35:08.000000
указывать интервалы времени где?
>формат поля timestamp Смените лучшэ на timestamptz. https://wiki.postgresql.org/wiki/Don%27t_Do_This#Don.27t_use_timestamp_.28without_time_zone.29 >указывать интервалы времени где? В create table.
Обсуждают сегодня