72 похожих чатов

Всем привет! есть такая процедура CREATE OR REPLACE PROCEDURE generate_partition(_begindate

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

5 ответов

18 просмотров

> т.к форматы дат разные Не так как "форматы дат разные", а так как ваша дата преобразована в формат этого поля (timestamptz, видимо, кстати, зачем мне его угадывать?) -- и получилась ровно одна микросекунда в полночь этой даты. А указывать надо интэрвалы времени. (Точнее, конечно, не надо. Поскольку партицыонирование в postgres не очень хорошэе, и навредить можэт очень легко. Потому в подавляющем большынстве случаев новички только создают себе проблемы попыткой партицыонировать postgres).

Михаил Регуш- Автор вопроса
Ilya Anfimov
> т.к форматы дат разные Не так как "форматы дат ...

да, верно, формат поля timestamp, забыл на это указать не очень понял про микросекунды, в сообщении дату 2022-06-17 12:00:00.000000 указал для примера, она может иметь любой вид - 2022-06-17 12:35:08.000000

Михаил Регуш- Автор вопроса
Михаил Регуш
да, верно, формат поля timestamp, забыл на это ука...

>формат поля timestamp Смените лучшэ на timestamptz. https://wiki.postgresql.org/wiki/Don%27t_Do_This#Don.27t_use_timestamp_.28without_time_zone.29 >указывать интервалы времени где? В create table.

Похожие вопросы

Обсуждают сегодня

Гайс, вопрос для разносторонее развитых: читаю стрим с юарта, нада выделять с него фреймы с определенной структурой, если ли чо готовое, или долбаться с ринг буффером? нада у...
Vitaly
9
Недавно Google Project Zero нашёл багу в SQLite с помощью LLM, о чём достаточно было шумно в определённых интернетах, которые сопровождались рассказами, что скоро всех "ибешни...
Alex Sherbakov
5
длина пакета фиксированная, или меняется?
Okhsunrog
7
Вот еще странный косяк, подскажите как бороться. Я git clone сделал себе всего embassy и примеры там запускаю. Всё хорошо. Но вот решил в cargo.toml зависимости не как в приме...
Lukutin R2AJP
5
А в каком формате фреймы? Сам формат сейчас придумываешь, или что-то готовое нужно распарсить?
Okhsunrog
5
https://github.com/erlang/otp/blob/OTP-27.1/lib/kernel/src/logger_h_common.erl#L174 https://github.com/erlang/otp/blob/OTP-27.1/lib/kernel/src/logger_olp.erl#L76 15 лет назад...
Maksim Lapshin
20
Добрый вечер, Пока не совсем понимаю как наладить общение между телеграм ботом и ПО для работы с сим боксом. По самому боту так понял: - Нужен некий баланс, который можно поп...
Magic
6
Всем привет, нужна как никогда, нужна помощь с IO в загрузчике. Пишу в code16 после установки сегментных регистров, пишу вывод символа. Пробовал 2 варианта: # 1 mov $0x0E, %a...
Shadow Akira
14
Раз начали говорить про embassy, то присоединюсь со своими парой вопросов. 1) Есть ли сопоставимые аналоги для асинхронного кода в emdebbed? 2) Можно ли внутри задач embassy ...
NI_isx
6
сделал сайт, прикрутил в боте сайт, и виджет логина. как автоматически логинить пользователя в аккаунт(телеграм), при входе с бота?
Александра Чернивецкая
5
Карта сайта